# UNIT - I

# **BASIC CONCEPTS**

Review of number systems-representation-conversions, Review of Boolean algebra- theorems, sum of product and product of sum simplification, canonical forms min term and max term, Simplification of Boolean expressions-Karnaugh map, completely and incompletely specified functions, Implementation of Boolean expressions using universal gates, Tabulation methods.

# Introduction

Basically there are two types of signals in electronics,

- i) Analog It is a continuous wave that keeps on changing over a time period.
- ii) Digital It is discrete in nature.

# Digital systems:

# Advantages:

- Digital systems are interfaced well with computers and are easy to control with software.
- New features can often be added to a digital system without changing hardware.
- Often this can be done outside of the factory by updating the product's software. So, the product's design errors can be corrected after the product is in a customer's hands.
- Information storage can be easier in digital systems.
- ✤ The noise-immunity of digital systems permits data to be stored and retrieved without degradation.
- In a digital system, as long as the total noise is below a certain level, the information can be recovered perfectly.

## Disadvantages:

- In some cases, digital circuits use more energy than analog circuits to accomplish the same tasks, thus producing more heat as well. In portable or battery-powered systems this can limit use of digital systems.
- Digital circuits are sometimes more expensive, especially in small quantities.
- For example, light, temperature, sound, electrical conductivity, electric and magnetic fields are analog.

# NUMBER SYSTEMS – DECIMAL, BINARY, OCTAL, HEXADECIMAL

# **\*** Discuss the various number system conversions with examples.

Many number systems are in use in digital technology. The most common are the decimal, binary, octal, and hexadecimal systems.

Types of Number Systems are

- Decimal Number system
- ✤ Binary Number system
- ✤ Octal Number system
- ✤ Hexadecimal Number system

#### **Table: Types of Number Systems**

| DECIMAL | BINARY | OCTAL | HEXADECIMAL |
|---------|--------|-------|-------------|
| 0       | 0000   | 0     | 0           |
| 1       | 0001   | 1     | 1           |
| 2       | 0010   | 2     | 2           |
| 3       | 0011   | 3     | 3           |
| 4       | 0100   | 4     | 4           |
| 5       | 0101   | 5     | 5           |
| 6       | 0110   | 6     | 6           |
| 7       | 0111   | 7     | 7           |
| 8       | 1000   | 10    | 8           |
| 9       | 1001   | 11    | 9           |
| 10      | 1010   | 12    | А           |
| 11      | 1011   | 13    | В           |
| 12      | 1100   | 14    | С           |
| 13      | 1101   | 15    | D           |
| 14      | 1110   | 16    | E           |
| 15      | 1111   | 17    | F           |

# Table: Number system and their Base value

| Number Systems |      |                                 |  |  |
|----------------|------|---------------------------------|--|--|
| System         | Base | Digits                          |  |  |
| Binary         | 2    | 0 1                             |  |  |
| Octal          | 8    | 0 1 2 3 4 5 6 7                 |  |  |
| Decimal        | 10   | 0 1 2 3 4 5 6 7 8 9             |  |  |
| Hexadecimal    | 16   | 0 1 2 3 4 5 6 7 8 9 A B C D E F |  |  |

#### Number system Conversions:

Converting from one code form to another code form is called code conversion, like converting from binary to decimal or converting from hexadecimal to decimal.

#### **Binary-To-Decimal Conversion:**

Any binary number can be converted to its decimal equivalent simply by summing together the weights of the various positions in the binary number which contain a 1.

*Example:* Convert 10110<sub>2</sub> into a decimal number.

The decimal equivalent number is given as:  $1 \times 2^4 + 0 \times 2^3 + 1 \times 2^2 + 1 \times 2^1 + 0 \times 2^0$  = 16 + 0 + 4 + 2 + 0 $= 22_{10}$ .

**Decimal to binary Conversion:** Convert 25<sub>10</sub> to Binary.

| Division | Remainder             | Binary                    |
|----------|-----------------------|---------------------------|
| 25/2     | = 12 + remainder of 1 | 1 (Least Significant Bit) |
| 12/2     | = 6 + remainder of 0  | 0                         |
| 6/2      | = 3 + remainder of 0  | 0                         |
| 3/2      | = 1 + remainder of 1  | 1                         |
| 1/2      | = 0 + remainder of 1  | 1 (Most Significant Bit)  |
| Result   | 2510                  | = 11001 <sub>2</sub>      |

Binary to octal: Convert 100 111 010<sub>2</sub> to octal.

Example:  $100\ 111\ 010_2 = (100)\ (111)\ (010)_2 = 4\ 7\ 2_8$ 

Octal to Binary: Convert 372<sub>8</sub> to Binary. 372 Octal 372 Octal 372 Octal 372 Octal 372 Octal 111 010 $1\frac{1}{7} \frac{1}{6} \frac{1}{5} \frac{1}{4} \frac{1}{3} \frac{0}{2} \frac{1}{1} \frac{0}{0}$  Binary

#### Decimal to octal: Convert 177<sub>10</sub> to Binary.

| Division | Result                | Binary                    |
|----------|-----------------------|---------------------------|
| 177/8    | = 22 + remainder of 1 | 1 (Least Significant Bit) |
| 22/ 8    | = 2 + remainder of 6  | 6                         |
| 2 / 8    | = 0 + remainder of 2  | 2 (Most Significant Bit)  |
| Result   | 177 <sub>10</sub>     | = 261 <sub>8</sub>        |
| Binary   |                       | $= 010110001_2$           |

*Octal to Decimal: convert* (71263)<sub>8</sub> *to Decimal.* **Example:** 



**Decimal to Hexadecimal:** Convert 378<sub>10</sub> to Hexadecimal.

| Division | Result                 | Hexadecimal                 |
|----------|------------------------|-----------------------------|
| 378/16   | = 23 + remainder of 10 | A (Least Significant Bit)23 |
| 23/16    | = 1 + remainder of 7   | 7                           |
| 1/16     | = 0 + remainder of 1   | 1 (Most Significant Bit)    |
| Result   | 37810                  | $= 17A_{16}$                |
| Binary   |                        | $= 0001 \ 0111 \ 1010_2$    |

Binary-To-Hexadecimal: Convert 1011 0010 1111<sub>2</sub> to Hexadecimal.

Example:  $1011\ 0010\ 1111_2 = (1011)\ (0010)\ (1111)_2 = B\ 2\ F_{16}$ 

*Hexadecimal to binary: Convert E*6<sub>16</sub> *to Binary.* 



# Octal-To-Hexadecimal Hexadecimal-To-Octal Conversion:

- ✤ Convert Octal (Hexadecimal) to Binary first.
- Regroup the binary number by three bits per group starting from LSB if Octal is required.
- \* Regroup the binary number by four bits per group starting from LSB if Hexadecimal is required.

Octal to Hexadecimal: Convert 26508 to Hexadecimal.

| Octal                           | Hexadecimal                             |
|---------------------------------|-----------------------------------------|
| = 2650                          |                                         |
| = <b>010</b> 110 <b>101</b> 000 | = <b>0101</b> 1010 <b>1000</b> (Binary) |
| Result                          | =(5A8) <sub>16</sub>                    |

*Hexadecimal to octal: Convert* (5A8)<sub>16</sub>*Hexadecimal to Octal.* 

| Hexadecimal         | Octal                                    |
|---------------------|------------------------------------------|
| (5A8) <sub>16</sub> | = <b>0101</b> 1010 <b>1000</b> (Binary)  |
|                     | = <b>010</b> 110 <b>101</b> 000 (Binary) |
| Result              | = 2650 (Octal)                           |

\*\*\*\*\*\*\*

# 1's and 2's complement:

## **\*** Explain about 1's and 2's complement with an example.

- Complements are used in digital computers to simplify the subtraction operation and for logical manipulation.
- There are TWO types of complements for each base-r system: the radix complement and the diminished radix complement.
- The first is referred to as the r's complement and the second as the (r -1)'s complement, when the value of the base r is substituted in the name.
- ✤ The two types are referred to as the 2's complement and 1's complement for binary numbers and the 10's complement and 9's complement for decimal numbers.

## Note:

- The 1's complement of a binary number is the number that results when we change all 1's to zeros and the zeros to ones.
- The 2's complement is the binary number that results when we add 1 to the 1's complement.
- It is used to represent negative numbers.

## 2's complement=1's complement+1

| Example 1)<br>Sol: | 1                                 | nber                    |
|--------------------|-----------------------------------|-------------------------|
| Example 2)<br>Sol: | : Find 1's compler<br>1 0 0 1 nur | ment of $(1001)_2$ nber |

 $\begin{array}{c} 0 \ 1 \ 1 \ 0 \\ + \ 1 \end{array} \quad 1's \text{ complement} \\ \end{array}$ 

0111

# Diminished Radix Complement:

Given a number N in base r having n digits, the (r-1)'s complement of N, i.e., its diminished radix complement, is defined as  $(r^n-1) - N$ .

The 9's complement of 546700 is 999999 - 546700 = 453299.

The 9's complement of 012398 is 999999 - 012398 = 987601.

#### Radix Complement:

The *r*'s complement of an *n*-digit number *N* in base *r* is defined as  $r^n - N$  for  $N \neq 0$  and as 0 for N = 0.

For examples:

| The 10's complement of | 012398 | is | 987602 |
|------------------------|--------|----|--------|
| The 10's complement of | 246700 | is | 753300 |

#### Model 1:

Using 10's complement, subtract 72532 - 3250.

| M =                          | 72532         |
|------------------------------|---------------|
| 10's complement of $N = +$   | 96750         |
| Sum =                        | 169282        |
| Discard end carry $10^5 = -$ | <u>100000</u> |
| Answer =                     | 69282         |

(May 2010)

Model 2:

Using 10's complement, subtract 3250 – 72532.

$$M = 03250$$
  
10's complement of  $N = + \frac{27468}{30718}$   
Sum = 30718

#### Model 3:

Given the two binary numbers X = 1010100 and Y = 1000011, perform the subtraction (a) X - Y and (b) Y - X by using 2's complements.

(a) 
$$X = 1010100$$
  
2's complement of  $Y = + 0111101$   
Sum = 10010001  
Discard end carry  $2^7 = -10000000$   
Answer:  $X - Y = 0010001$   
(b)  $Y = 1000011$   
2's complement of  $X = 0101100$   
Sum = 1101111

There is no end carry. Therefore, the answer is Y - X = -(2's complement of 1101111) = -0010001.

# Model 4:

Given the two binary numbers X=1010100 and Y=1000011, perform the subtraction (a) X-Y and (b) Y-X by using 1's complements.

(a) 
$$X - Y = 1010100 - 1000011$$
  
 $X = 1010100$   
1's complement of  $Y = + 0111100$   
Sum = 10010000  
Endaround carry = + \_\_\_\_\_1  
Answer:  $X - Y = 0010001$   
(b)  $Y - X = 1000011 - 1010100$   
 $Y = 1000011$   
1's complement of  $X = + 0101011$   
Sum = 1101110

There is no end carry. Therefore, the answer is Y - X = -(1's complement of 1101110) = -0010001.

\*\*\*\*\*

## **ARITHMETIC OPERATIONS**

## **Binary** Addition:

## **Rules of Binary Addition**

- 0 + 0 = 0
- 0 + 1 = 1
- 1+0=1
- 1 + 1 = 0, and carry 1 to the next more significant bit

Example:

## Add: 00011010 + 00001100 = 00100110

|     |   | 1 | 1 |   |   |   |   |
|-----|---|---|---|---|---|---|---|
| 0   | 0 | 0 | 1 | 1 | 0 | 1 | 0 |
| + 0 | 0 | 0 | 0 | 1 | 1 | 0 | 0 |
| 0   | 0 | 1 | 0 | 0 | 1 | 1 | 0 |

# **Binary** Subtraction:

# **Rules of Binary Subtraction**

- 0 0 = 0•
- 0 1 = 1, and borrow 1 from the next more significant bit •
- 1 0 = 1•
- 1 1 = 0•

# **Example:**

| Sub: | 00100101 - 00010001 = 00010100 |   |   |   |   |   |   |   |
|------|--------------------------------|---|---|---|---|---|---|---|
|      | 0                              | 0 | 1 | 0 | 0 | 1 | 0 | 1 |
|      | - 0                            | 0 | 0 | 1 | 0 | 0 | 0 | 1 |
|      |                                |   |   |   |   |   |   |   |
|      | 0                              | 0 | 0 | 1 | 0 | 1 | 0 | 0 |
|      |                                |   |   |   |   |   |   |   |

# **Binary Multiplication:**

# **Rules of Binary Multiplication**

1

1.

0

- $0 \ge 0 = 0$ •
- $0 \ge 1 = 0$ ٠
- $1 \ge 0 = 0$ •
- $1 \ge 1$ , and no carry or borrow bits •

## Exampl

| (a)        | 0111    | × 1101  |   |            |    |   |   |   |               |
|------------|---------|---------|---|------------|----|---|---|---|---------------|
|            |         |         |   | 0          | 1  | 1 | 1 |   | Multiplicand  |
|            |         |         | × | 1          | 1  | 0 | 1 |   | Multiplier    |
|            |         |         |   | 0          | 1  | 1 | 1 |   |               |
|            |         |         | 0 | 0          | 0  | 0 |   |   | Partial       |
|            |         | 0       | 1 | 1          | 1  |   |   |   | Products      |
|            | 0       | 1       | 1 | 1          |    |   |   |   |               |
|            | 1       | 0       | 1 | 1          | 0  | 1 | 1 |   | Final Product |
| <i>(b)</i> | 1.011 > | × 10.01 |   |            |    |   |   |   |               |
|            |         |         |   | 1.         | 0  | 1 |   | 1 | Multiplican   |
|            |         |         |   | $\times 1$ | 0. | 0 |   | 1 | Multiplier    |
|            |         |         |   | 1          | 0  | 1 |   | 1 |               |
|            |         |         | 0 | 0          | 0  | 0 |   |   | Partial       |
|            |         |         | 0 | 0          | 0  |   |   |   | Products      |
|            |         | 0       | 0 | 0          | 0  |   |   |   | Froducts      |

0

0

1

1

**Final Product** 

# **Binary Division:**

Binary division is the repeated process of subtraction, just as in decimal division.

**Example :** (*a*) 11001 ÷ 101

|     |         |      |   | 1 | 0 | 1  |   |   |   |
|-----|---------|------|---|---|---|----|---|---|---|
|     | 1       | 0    | 1 | 1 | 1 | 0  | 0 | 1 | _ |
|     |         |      |   | 1 | 0 | 1  |   |   |   |
|     |         |      |   | 0 | 0 | 1  | 0 | 1 |   |
|     |         |      |   |   |   | 1  | 0 | 1 |   |
|     |         |      |   |   |   | 0  | 0 | 0 |   |
| (b) | 11110 ÷ | 1001 |   |   |   |    |   |   |   |
|     |         |      |   |   | 1 | 1. | 0 | 1 | 0 |
| 1   | 0       | 0    | 1 | 1 | 1 | 1  | 1 | 0 |   |
|     |         |      |   |   | 1 | 0  | 0 | 1 |   |
|     |         |      |   | 0 | 1 | 1  | 0 | 0 |   |
|     |         |      |   |   | 1 | 0  | 0 | 1 |   |
|     |         |      |   |   | 1 | 0  | 0 | 0 | 0 |
|     |         |      |   |   |   | 1  | 0 | 0 | 1 |
|     |         |      |   |   |   |    | 1 | 1 | 0 |
|     |         |      |   |   |   | 1  | 0 | 0 | 1 |
|     |         |      |   |   |   |    | 1 | 0 | 1 |

\*\*\*\*\*

# CODES

# Explain the various codes used in digital systems with an example.

- In digital systems a variety of codes are used to serve different purposes, such as data entry, arithmetic operation, error detection and correction, etc.
- > Selection of a particular code depends on the requirement.
- Codes can be broadly classified into five groups.
  - (i) Weighted Binary Codes
  - (ii) Non-weighted Codes
  - (iii) Error-detection Codes
  - (iv) Error-correcting Codes
  - (v) Alphanumeric Codes

# Weighted Binary Codes

If each position of a number represents a specific weight then the coding scheme is called weighted binary code.

# BCD Code or 8421 Code:

- > The full form of BCD is 'Binary-Coded Decimal'. Since this is a coding scheme relating decimal and binary numbers, *four bits are required* to code each decimal number.
- For example,  $(35)_{10}$  is represented as 0011 0101 using BCD code, rather than  $(100011)_2$
- Example: Give the BCD equivalent for the decimal number 589.

| The decimal number is              | 5        | 8    | 9    |
|------------------------------------|----------|------|------|
| BCD code is                        | 0101     | 1000 | 1001 |
| Hence, $(589)_{10} = (01011)^{-1}$ | 0001001) | BCD  |      |

# 2421 Code:

- Another weighted code is 2421 code. The weights assigned to the four digits are 2, 4, 2, and 1.
- > The 2421 code is the same as that in BCD from 0 to 4. However, it varies from 5 to 9.
- For example, in this case the bit combination 0100 represents decimal 4; whereas the bit combination 1101 is interpreted as the decimal 7, as obtained from  $2 \times 1 + 1 \times 4 + 0 \times 2 + 1 \times 1 = 7$ .
- > This is also a self-complementary code.

# BCD Addition:

Examples:

> Consider the addition of 184 + 576 = 760 in BCD:

| BCD        | 1     | 1     |      |      |
|------------|-------|-------|------|------|
|            | 0001  | 1000  | 0100 | 184  |
|            | +0101 | 0111  | 0110 | +576 |
| Binary sum | 0111  | 10000 | 1010 |      |
| Add 6      |       | 0110  | 0110 |      |
| BCD sum    | 0111  | 0110  | 0000 | 760  |

> Add the following BCD numbers: (a) 1001 and 0100, (b) 00011001 and 00010100

| Solution                                                                                                                                                                |                                        |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|
| (a) $1 0 0 1$<br>+ 0 1 0 0                                                                                                                                              |                                        |
| $1  1  0  1  \rightarrow \text{Invalid BCD number}$                                                                                                                     | 9 - 19 - 19 - 19 - 19 - 19 - 19 - 19 - |
| $\begin{array}{c} +0 & 1 & 1 & 0 \\ \hline 1 & 0 & 0 & 1 \\ \hline 1 & 0 & 0 & 0 \end{array} \rightarrow \text{Add } 6 \end{array}$                                     | +4                                     |
| $\underbrace{\begin{array}{ccc} 0 & 0 & 1 \\ 1 & & \\ 1 & & \\ 1 & & \\ 3 & & \\ 3 & & \\ \end{array}}_{3} \rightarrow \text{Valid BCD number}$                         | 13 <sub>10</sub>                       |
| (b) 0 0 0 1 1 0 0 1                                                                                                                                                     |                                        |
| +0 0 0 1 0 1 0 0                                                                                                                                                        |                                        |
| $0$ $0$ $1$ $0$ $1$ $1$ $0$ $1 \rightarrow$ Right group is invalid                                                                                                      | 19                                     |
| $+0$     $0 \rightarrow \text{Add } 6$                                                                                                                                  | +14                                    |
| $\underbrace{\begin{array}{ccc} 0 & 1 & 1 \\ 3 \end{array}}_{3} \underbrace{\begin{array}{ccc} 0 & 0 & 1 & 1 \\ 3 \end{array}}_{3} \rightarrow \text{Valid BCD number}$ | 33,                                    |

|                  | /           |      | 2        |              |   |
|------------------|-------------|------|----------|--------------|---|
| Decimal<br>Digit | BCD<br>8421 | 2421 | Excess-3 | 8, 4, -2, -1 |   |
| 0                | 0000        | 0000 | 0011     | 0000         |   |
| 1                | 0001        | 0001 | 0100     | 0111         |   |
| 2                | 0010        | 0010 | 0101     | 0110         |   |
| 3                | 0011        | 0011 | 0110     | 0101         |   |
| 4                | 0100        | 0100 | 0111     | 0100         |   |
| 5                | 0101        | 1011 | 1000     | 1011         |   |
| 6                | 0110        | 1100 | 1001     | 1010         |   |
| 7                | 0111        | 1101 | 1010     | 1001         |   |
| 8                | 1000        | 1110 | 1011     | 1000         |   |
| 9                | 1001        | 1111 | 1100     | 1111         |   |
|                  | 1010        | 0101 | 0000     | 0001         |   |
| Unused           | 1011        | 0110 | 0001     | 0010         |   |
| bit              | 1100        | 0111 | 0010     | 0011         |   |
| combi-           | 1101        | 1000 | 1101     | 1100         |   |
| nations          | 1110        | 1001 | 1110     | 1101         |   |
|                  | 1111        | 1010 | 1111     | 1110         |   |
|                  |             |      |          |              | ĩ |

Four Different Binary Codes for the Decimal Digits

#### Non-weighted Codes

- ▶ It basically means that each position of the binary number is not assigned a fixed value.
- Excess-3 codes and Gray codes are such non-weighted codes.

#### Excess-3 code:

- > This code assignment is obtained from the corresponding value of 4-bit binary code after adding 3 to the given decimal digit.
- **Example:** 1000 of 8421 (BCD) = 1011 in Excess-3.

#### [NOV 2020]

| * | Convert (367 | ) <sub>10</sub> into its Excess-3 code. | and    | Decimal       | (643) to  | Excess - 3 code |
|---|--------------|-----------------------------------------|--------|---------------|-----------|-----------------|
|   | Solution.    | The decimal number is                   | 3      | 6             | 7         |                 |
|   |              | Add 3 to each bit                       | +3     | +3            | +3        |                 |
|   |              | Sum                                     | 6      | 9             | 10        |                 |
|   | Co           | nverting the above sum in               | to 4-b | it binary     | equivalen | t, we have a    |
|   | 4-k          | oit binary equivalent of                | 0110   | 1001          | 1010      |                 |
|   | He           | ence, the Excess-3 code for             | (367)1 | $_{0} = 0110$ | 1001 1010 | )               |
|   |              | Excess-3 code f                         | or 64. | 3 = 1001      | 0111 01   | 10              |

## Gray code:

- ▶ Gray code belongs to a class of code known as minimum change code, in which a number changes by only one bit as it proceeds from one number to the next.
- > This code finds use for shift encoders, in some types of analog-to-digital converters, etc.
- > The gray code is a reflective digital code which has the special property that any two subsequent numbers codes differ by only one bit. This is also called a *unit-distance code*.

| Decimal numbers | Binary code | Gray code |
|-----------------|-------------|-----------|
| 0               | 0000        | 0000      |
| 1               | 0001        | 0001      |
| 2               | 0010        | 0011      |
| 3               | 0011        | 0010      |
| 4               | 0100        | 0110      |
| 5               | 0101        | 0111      |
| 6               | 0110        | 0101      |
| 7               | 0111        | 0100      |
| 8               | 1000        | 1100      |
| 9               | 1001        | 1101      |
| 10              | 1010        | 1111      |
| 11              | 1011        | 1110      |
| 12              | 1100        | 1010      |
| 13              | 1101        | 1011      |
| 14              | 1110        | 1001      |
| 15              | 1111        | 1000      |

# Binary to Gray Code Conversion:

Any binary number can be converted into equivalent Gray code by the following steps:

- i) the MSB of the Gray code is the same as the MSB of the binary number;
- ii) the second bit next to the MSB of the Gray code equals the Ex-OR of the MSB and second bit of the binary number; it will be 0 if there are same binary bits or it will be 1 for different binary bits;
- iii) the third bit for Gray code equals the exclusive-OR of the second and third bits of the binary number, and similarly all the next lower order bits follow the same mechanism.



# Gray Code to Binary Code Conversion:

Any Gray code can be converted into an equivalent binary number by the following steps:

- i. The MSB of the binary number is the same as the MSB of the Gray code.
- ii. the second bit next to the MSB of the binary number equals the Ex-OR of the MSB of the binary number and second bit of the Gray code; it will be 0 if there are same binary bits or it will be 1 for different binary bits;
- iii. the third bit for the binary number equals the exclusive-OR of the second bit of the binary number and third bit of the Gray code, and similarly all the next lower order bits follow the same mechanism.

# Example:



## Error detecting codes

- When data is transmitted from one point to another, like in wireless transmission, or it is just stored, like in hard disks and memories, there are chances that data may get corrupted.
- $\blacktriangleright$  To detect these data errors, we use special codes, which are error detection codes.

## Two types of parity

- **Even parity:** Checks if there is an even number of ones; if so, parity bit is zero. When the number of one's is odd then parity bit is set to 1.
- ➤ Odd Parity: Checks if there is an odd number of ones; if so, parity bit is zero. When the number of one's is even then parity bit is set to 1.

# Error correcting code

- > Error-correcting codes not only detect errors, but also correct them.
- This is used normally in Satellite communication, where turn-around delay is very high as is the probability of data getting corrupt.

# Hamming codes

- Hamming code adds a minimum number of bits to the data transmitted in a noisy channel, to be able to correct every possible one-bit error.
- It can detect (not correct) two-bit errors and cannot distinguish between 1-bit and 2-bits inconsistencies. It can't in general detect 3(or more)-bits errors.

## **Alphanumeric Codes**

An alphanumeric code is a binary code of a group of elements consisting of ten decimal digits, the 26 letters of the alphabet (both in uppercase and lowercase), and a certain number of special symbols such as #, /, &, %, etc.

#### ASCII (American Standard Code for Information Interchange)

- ▶ It is actually a 7-bit code, where a character is represented with seven bits.
- > The character is stored as one byte with one bit remaining unused.
- > But often the extra bit is used to extend the ASCII to represent an additional 128 characters.

## EBCDIC codes

- > EBCDIC stands for *Extended Binary Coded Decimal Interchange*.
- It is also an alphanumeric code generally used in IBM equipment and in large computers for communicating alphanumeric data.
- ➢ For the different alphanumeric characters the code grouping in this code is different from the ASCII code. It is actually an 8-bit code and a ninth bit is added as the parity bit.

#### \*\*\*\*\*\*\*\*\*\*

#### **Boolean Algebra and Theorems**

#### Discuss the different postulates of Boolean theorems.

#### **Definition:**

- Boolean algebra is an algebraic structure defined by a set of elements B, together with two binary operators. '+' and '-', provided that the following postulates are satisfied.
- It can be used to simplify many a complex Boolean expression and also to transform the given expression into more useful and meaningful equivalent expression.

#### T1: Commutative Law

| (a) | A + | B = B | +A |
|-----|-----|-------|----|
|     |     |       |    |

(b) A B = B A

T2: Associative Law

(a) (A + B) + C = A + (B + C)

(b) (A B) C = A (B C)

## T3: Distributive Law

(a) A (B + C) = A B + A C(b) A + (B C) = (A + B) (A + C)

## T4: Identity Law

(a) A + A = A

(b) A A = A

T5: Negation Law  $(\overline{A}) = \overline{A}$  and  $(\overline{\overline{A}}) = A$ 

#### T6: Redundancy

(a) A + A B = A(b) A (A + B) = A

#### T7: Operations with '0' & '1'

- (a)  $\theta + A = A$
- (b) I A = A
- (c) l + A = l
- (d) 0A = 0
- **T8 : Complement laws** 
  - (a)  $\bar{A} + A = 1$ (b)  $\bar{A} \cdot A = 0$
- **T9:** (a)  $A + \overline{AB} = A + B$ (b) A.  $(\overline{A} + B) = A.B$

# Postulates of Boolean Algebra:

- The postulates of a mathematical system form the basic assumptions from which it is possible to deduce the rules, theorems, and properties of the system.
- > The following are the important postulates of Boolean algebra:

| 1. | 1*1 = 1       | 0+0=0.        |
|----|---------------|---------------|
| 2. | 1*0 = 0*1 = 0 | 0+1 = 1+0 = 1 |
| 3. | 0*0 = 0       | 1 + 1 = 1     |

- 4. 1' = 0 and 0' = 1.
- Many theorems of Boolean algebra are based on these postulates, which can be used to simplify Boolean expressions.

The operators and postulates have the following meanings:

- ✓ The binary operator + defines addition.
- $\checkmark$  The additive identity is 0.
- $\checkmark$  The additive inverse defines subtraction.
- ✓ The binary operator .(dot) defines multiplication.
- $\checkmark$  The multiplicative identity is 1.
- $\checkmark$  The only distributive law applicable is that of .(dot) over +:

 $a \cdot (b + c) = (a \cdot b) + (a \cdot c)$ 

# **Two-Valued Boolean Algebra:**

A two-valued Boolean algebra is defined on a set of two elements,  $B = \{0, 1\}$ , with rules for the two binary operators + and .(dot) as shown in the following operator tables.

| x | y | x·y | x | y | x + y | x | <b>x</b> ′ |
|---|---|-----|---|---|-------|---|------------|
| 0 | 0 | 0   | 0 | 0 | 0     | 0 | 1          |
| 0 | 1 | 0   | 0 | 1 | 1     | 1 | 0          |
| 1 | 0 | 0   | 1 | 0 | 1     |   |            |
| 1 | 1 | 1   | 1 | 1 | 1     |   |            |

# **Duality Principle:**

- The *duality principle* states that every algebraic expression deducible from the postulates of Boolean algebra remains valid if the operators and identity elements are interchanged.
- If the *dual* of an algebraic expression is desired, we simply interchange OR and AND operators and replace 1's by 0's and 0's by 1's.

# De-Morgan's theorem:

- 1. The complement of product is equal to the sum of their complements. (X.Y)'=X'+Y'
- 2. The complement of sum is equal to the product of their complements. (X+Y)' = X'.Y'

# **Basic Theorems:**

Postulates and Theorems of Boolean Algebra

| Postulate 2               | (a) | x + 0 = x                 | (b) | $x \cdot 1 = x$         |
|---------------------------|-----|---------------------------|-----|-------------------------|
| Postulate 5               | (a) | x + x' = 1                | (b) | $x \cdot x' = 0$        |
| Theorem 1                 | (a) | x + x = x                 | (b) | $x \cdot x = x$         |
| Theorem 2                 | (a) | x + 1 = 1                 | (b) | $x \cdot 0 = 0$         |
| Theorem 3, involution     |     | (x')' = x                 |     |                         |
| Postulate 3, commutative  | (a) | x + y = y + x             | (b) | xy = yx                 |
| Theorem 4, associative    | (a) | x + (y + z) = (x + y) + z | (b) | x(yz) = (xy)z           |
| Postulate 4, distributive | (a) | x(y+z) = xy + xz          | (b) | x + yz = (x + y)(x + z) |
| Theorem 5, DeMorgan       | (a) | (x + y)' = x'y'           | (b) | (xy)' = x' + y'         |
| Theorem 6, absorption     | (a) | x + xy = x                | (b) | x(x + y) = x            |

THEOREM 1(a): x + x = x.

| Statement                 | Justification  |
|---------------------------|----------------|
| $x + x = (x + x) \cdot 1$ | postulate 2(b) |
| = (x+x)(x+x')             | 5(a)           |
| = x + xx'                 | 4(b)           |
| = x + 0                   | 5(b)           |
| = x                       | 2(a)           |

THEOREM 1(b):  $x \cdot x = x$ .

| Statement            | Justification  |
|----------------------|----------------|
| $x \cdot x = xx + 0$ | postulate 2(a) |
| = xx + xx'           | 5(b)           |
| =x(x+x')             | 4(a)           |
| $= x \cdot 1$        | 5(a)           |
| = x                  | 2(b)           |

**THEOREM 2(a):** x + 1 = 1.

| Statement                 | Justification  |
|---------------------------|----------------|
| $x + 1 = 1 \cdot (x + 1)$ | postulate 2(b) |
| = (x + x')(x + 1)         | 5(a)           |
| $= x + x' \cdot 1$        | 4(b)           |
| = x + x'                  | 2(b)           |
| = 1                       | 5(a)           |

**THEOREM 2(b):**  $x \cdot 0 = 0$  by duality.

**THEOREM 3:** (x')' = x. From postulate 5, we have x + x' = 1 and  $x \cdot x' = 0$ , which together define the complement of x. The complement of x' is x and is also (x')'.

THEOREM 6(a): x + xy = x.

| Statement                 | Justification  |
|---------------------------|----------------|
| $x + xy = x \cdot 1 + xy$ | postulate 2(b) |
| = x(1 + y)                | 4(a)           |
| = x(y + 1)                | 3(a)           |
| $= x \cdot 1$             | 2(a)           |
| = x                       | 2(b)           |

**THEOREM 6(b):** x(x + y) = x by duality.

\*\*\*\*\*\*

#### **Boolean Functions**

- Boolean algebra is an algebra that deals with binary variables and logic operations.
- A Boolean function described by an algebraic expression consists of binary variables, the constants 0 and 1, and the logic operation symbols.
- For a given value of the binary variables, the function can be equal to either 1 or 0.

**Example:** Consider the Boolean function, F1 = x + y'z

> The gate implementation of F1 is shown below.



#### **Examples:**

Simplify the following Boolean functions to a minimum number of literals.

1. 
$$x(x' + y) = xx' + xy = 0 + xy = xy$$
.

2. 
$$x + x'y = (x + x')(x + y) = 1(x + y) = x + y$$
.

3. 
$$(x + y)(x + y') = x + xy + xy' + yy' = x(1 + y + y') = x$$
.

4. 
$$xy + x'z + yz = xy + x'z + yz(x + x')$$
  
=  $xy + x'z + xyz + x'yz$   
=  $xy(1 + z) + x'z(1 + y)$   
=  $xy + x'z$ .

5. (x + y)(x' + z)(y + z) = (x + y)(x' + z), by duality from function 4.

# Complement of a function:

> The complement of a function F is obtained from an interchange of 0's for 1's and 1's for 0's in the value of F.

#### Example: 1. Sin

Simplify:-  

$$(A + B + C)' = (A + x)'$$
 let  $B + C = x$   
 $= A'x'$  by theorem 5(a) (DeMorgan)  
 $= A'(B + C)'$  substitute  $B + C = x$   
 $= A'(B'C')$  by theorem 5(a) (DeMorgan)  
 $= A'B'C'$  by theorem 4(b) (associative)

2. Find the complement of the functions F1 = x'yz' + x'y'z and F2 = x(y'z' + yz). Solution:

By applying DeMorgan's theorem, the complements are obtained as follows:

$$F'_{1} = (x'yz' + x'y'z)' = (x'yz')'(x'y'z)' = (x + y' + z)(x + y + z')$$

$$F'_{2} = [x(y'z' + yz)]' = x' + (y'z' + yz)' = x' + (y'z')'(yz)'$$

$$= x' + (y + z)(y' + z')$$

$$= x' + yz' + y'z$$

3. Find the complement of the functions F1 = x'yz' + x'y'z and F2 = x(y'z' + yz) by taking their duals and complementing each literals.

Solution:

- 1.  $F_1 = x'yz' + x'y'z$ . The dual of  $F_1$  is (x' + y + z')(x' + y' + z). Complement each literal:  $(x + y' + z)(x + y + z') = F'_1$ .
- 2.  $F_2 = x(y'z' + yz)$ . The dual of  $F_2$  is x + (y' + z')(y + z). Complement each literal:  $x' + (y + z)(y' + z') = F'_2$ .

\*\*\*\*\*

# LOGIC GATES

## Discuss the various logic gates with its truth table.

- ◆ A logic gate is an idealized or physical device implementing a Boolean function.
- It performs a logical operation on one or more logical inputs, and produces a single logical output.

# Positive and Negative Logic:

- ◆ The binary variables have two states, i.e. the logic '0' state or the logic '1' state.
- These are represented by two different voltage levels or two different current levels.
- If the more positive of the two voltage or current levels represents a logic '1' and the less positive of the two levels represents a logic '0', then the logic system is referred to as a *positive logic system*.
- If the more positive of the two voltage or current levels represents a logic '0' and the less positive of the two levels represents a logic '1', then the logic system is referred to as a *negative logic system*.

## Truth Table

A truth table lists all possible combinations of input binary variables and the corresponding outputs of a logic system.

| Name                               | Graphic<br>symbol       | Algebraic<br>function             | Truth<br>table                                                                                          |
|------------------------------------|-------------------------|-----------------------------------|---------------------------------------------------------------------------------------------------------|
| AND                                | x                       | $F = x \cdot y$                   | x y F<br>0 0 0<br>0 1 0<br>1 0 0<br>1 1 1                                                               |
| OR                                 | x<br>y                  | F = x + y                         | x y F<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 1                                                               |
| Inverter                           | x>oF                    | F = x'                            | x F<br>0 1<br>1 0                                                                                       |
| Buffer                             | x                       | F = x                             | x F<br>0 0<br>1 1                                                                                       |
| NAND                               | xp                      | F = (xy)'                         | $\begin{array}{c ccc} x & y & F \\ \hline 0 & 0 & 1 \\ 0 & 1 & 1 \\ 1 & 0 & 1 \\ 1 & 1 & 0 \end{array}$ |
| NOR                                | x                       | F = (x + y)'                      | x y F<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 0                                                               |
| Exclusive-OR<br>(XOR)              | \$, <b>₩</b> , <b>₽</b> | $F = xy' + x'y$ $= x \oplus y$    | x y F<br>0 0 0<br>0 1 1<br>1 0 1<br>1 1 0                                                               |
| Exclusive-NOR<br>or<br>equivalence | \$, <b>₩</b> , <b>₽</b> | $F = xy + x'y'$ $= (x \oplus y)'$ | x y F<br>0 0 1<br>0 1 0<br>1 0 0<br>1 1 1                                                               |

## Universal Gates(NAND & NOR)

- The OR, AND and NOT gates are the three basic logic gates, It can be used to construct the logic circuit for any given Boolean expression.
- The NOR and NAND gate have the property that they individually can be used to hardwareimplement a logic circuit corresponding to any given Boolean expression.
- It is possible to use either only NAND gates or only NOR gates to implement any Boolean expression.
- This is so because a combination of NAND gates or a combination of NOR gates can be used to perform functions of any of the basic logic gates.
- ✤ It is for this reason that NAND and NOR gates are universal gates.

Implementation of basic gates using NAND gate:

Inverter (NOT gate):



AND gate:



OR gate:



Implementation of basic gates using NOR gate:

Inverter (NOT gate):



AND gate:



**OR gate:** 



# NAND–NOR implementations:

- Digital circuits are frequently constructed with NAND or NOR gates rather than with AND and OR gates.
- NAND and NOR gates are easier to fabricate with electronic components and are the basic gates used in all IC digital logic families.
- Because of the prominence of NAND and NOR gates in the design of digital circuits, rules and procedures have been developed for the conversion from Boolean functions given in terms of AND, OR, and NOT into equivalent NAND and NOR logic diagrams.

# Only NAND/NOR gate circuit:

- A convenient way to implement a Boolean function with NAND/NOR gates is to obtain the simplified Boolean function in terms of Boolean operators and then convert the function to NAND/NOR logic.
- The conversion of an algebraic expression from AND, OR, and complement to NAND/NOR can be done by simple circuit manipulation techniques that change AND–OR diagrams to NAND/NOR diagrams.



# NAND Implementation Procedure:

- ✓ Draw the AOI logic of given Boolean expression.
- $\checkmark$  Add bubble on input of OR gate & output of AND gate.
- $\checkmark$  Add an Inverter on each line that received bubbles.
- ✓ Eliminate double inversions
- ✓ Replace all by NAND gates

Example:

1. Implement F = AB + CD using only NAND gate.



2. Implement the following Boolean function with NAND gates: F(x, y, z) = (1, 2, 3, 4, 5, 7)



(Dec 2018) (Dec 2014)





# **NOR Implementation Procedure:**

- $\checkmark$  Draw the AOI logic of given Boolean expression.
- $\checkmark$  Add bubble on input of AND gate & output of OR gate.
- $\checkmark$  Add an Inverter on each line that received bubbles.
- ✓ Eliminate double inversions
- ✓ Replace all by NOR gates

# Example:

1. Implement F = (A + B)(C + D)E using only NOR gate.



2. Implement F = (AB' + A'B)(C + D') using only NOR gate.



\*\*\*\*\*

# CANONICAL AND STANDARD FORMS

# Explain canonical SOP & POS form with suitable example.

- Binary logic values obtained by the logical functions and logic variables are in binary form. An arbitrary logic function can be expressed in the following forms.
  - (i) Sum of the Products (SOP)
  - (ii) Product of the Sums (POS)
- Boolean functions expressed as a sum of minterms or product of maxterms are said to be in canonical form.

## **Product term:**

The AND function is referred to as a product. The variable in a product term can appear either in complementary or uncomplimentary form. Example: ABC'

## Sum term:

The OR function is referred to as a Sum. The variable in a sum term can appear either in complementary or uncomplimentary form. Example: A+B+C'

# **Sum of Product (SOP):**

The logical sum of two or more logical product terms is called sum of product expression. It is basically an OR operation of AND operated variables. Example: Y=AB+BC+CA

# **Product of Sum (POS):**

The logical product of two or more logical sum terms is called product of sum expression. It is basically an AND operation of OR operated variables. Example: Y=(A+B).(B+C).(C+A)

# Minterm:

A product term containing all the K variables of the function in either complementary or uncomplimentary form is called Minterm or standard product.

## Maxterm:

➤ A sum term containing all the K variables of the function in either complementary or uncomplimentary form is called Maxterm or standard sum.

|   |   |   | Minterms |                | Maxte        | erms        |
|---|---|---|----------|----------------|--------------|-------------|
| x | y | z | Term     | Designation    | Term         | Designation |
| 0 | 0 | 0 | x'y'z'   | $m_0$          | x + y + z    | $M_0$       |
| 0 | 0 | 1 | x'y'z    | $m_1$          | x + y + z'   | $M_1$       |
| 0 | 1 | 0 | x'yz'    | $m_2$          | x + y' + z   | $M_2$       |
| 0 | 1 | 1 | x'yz     | $m_3$          | x + y' + z'  | $M_3$       |
| 1 | 0 | 0 | xy'z'    | $m_4$          | x' + y + z   | $M_4$       |
| 1 | 0 | 1 | xy'z     | $m_5$          | x' + y + z'  | $M_5$       |
| 1 | 1 | 0 | xyz'     | m <sub>6</sub> | x' + y' + z  | $M_6$       |
| 1 | 1 | 1 | xyz      | $m_7$          | x' + y' + z' | $M_7$       |

Minterms and Maxterms for Three Binary Variables

# **Canonical SOP Expression:**

The minterms whose sum defines the Boolean function are those which give the 1's of the function in a truth table.

# Procedure for obtaining Canonical SOP expression:

- ✓ Examine each term in a given logic function. Retain if it is a minterm, continue to examine the next term in the same manner.
- ✓ Check for the variables that are missing in each product which is not minterm. Multiply the product by (X+X'), for each variable X that is missing.
- $\checkmark$  Multiply all the products and omit the redundant terms.

# Example 1:

# Express the Boolean function F = A + B'C as a sum of minterms. (Dec 2017)

# Solution:

The function has three variables: *A*, *B*, and *C*.

The first term A is missing two variables; therefore,

A = A(B + B') = AB + AB'

This function is still missing one variable, so

A = AB(C + C') + AB'(C + C')

= ABC + ABC' + AB'C + AB'C'

The second term B'C is missing one variable; hence,

B'C = B'C(A + A') = AB'C + A'B'C

Combining all terms, we have

F = A + B'C = ABC + ABC' + AB'C + AB'C' + A'B'C

But AB'C appears twice, and according to theorem 1 (x + x = x), it is possible to remove one of those occurrences.

Rearranging the minterms in ascending order, we finally obtain

F = A'B'C + AB'C + AB'C + ABC' + ABC= m1 + m4 + m5 + m6 + m7  $F(A, B, C) = \sum (1, 4, 5, 6, 7)$ 

# Example 2: Obtain the canonical sum of product form of the following function. (May 2014)

[NOV 2020]

F (A, B, C) = A + BC = A (B + B') (C + C') + BC (A + A') = (AB + AB') (C + C') + ABC + A'BC = ABC + AB'C + ABC' + AB'C' + ABC + A'BC = ABC + AB'C + ABC' + AB'C' + A'BC (as ABC + ABC = ABC)Hence the canonical sum of the product expression of the given function is

F (A, B) = ABC + AB'C + ABC' + AB'C' + A'BC.

# POS Form: F = (A'+B'+C')(A'+B+C')(A'+B'+C)(A'+B+C)(A+B'+C')

#### **Canonical POS Expression:**

The Maxterms whose product defines the Boolean function are those which give the 1's of the function in a truth table.

#### **Procedure for obtaining Canonical POS expression:**

- ✓ Examine each term in a given logic function. Retain if it is a maxterm, continue to examine the next term in the same manner.
- ✓ Check for the variables that are missing in each sum which is not maxterm. Add (X.X'), for each variable X that is missing.
- $\checkmark$  Expand the expression using distributive property eliminate the redundant terms.

#### Example1:

## Express the Boolean function F = xy + x'z as a product of maxterms.

#### Solution:

First, convert the function into OR terms by using the distributive law:

 $F = xy + x_z = (xy + x')(xy + z)$ = (x + x')(y + x')(x + z)(y + z)

= (x' + y)(x + z)(y + z)

The function has three variables: x, y, and z. Each OR term is missing one variable;

#### therefore,

 $x'+y = x' + y + z \cdot z' = (x' + y + z)(x' + y + z')$   $x + z = x + z + y \cdot y' = (x + y + z)(x + y' + z)$  $y + z = y + z + x \cdot x' = (x + y + z)(x' + y + z)$ 

Combining all the terms and removing those which appear more than once, we finally obtain  $F = (x + y + z)(x + y - z)(x_{-} + y + z)(x_{-} + y + z_{-}) = M0.M2.M4.M5$  $F(x, y, z) = \pi(0, 2, 4, 5)$ 

#### Example 2:

Obtain the canonical product of the sum form of the following function.F(A, B, C) = (A + B') (B + C) (A + C')(Dec 2012)

Solution:

 $\begin{array}{l} {\rm F}\ ({\rm A},\ {\rm B},\ {\rm C}) = ({\rm A}+{\rm B}')\ ({\rm B}+{\rm C})\ ({\rm A}+{\rm C}') \\ = ({\rm A}+{\rm B}'+0)\ ({\rm B}+{\rm C}+0)\ ({\rm A}+{\rm C}'+0) \\ = ({\rm A}+{\rm B}'+{\rm CC}')\ ({\rm B}+{\rm C}+{\rm AA}')\ ({\rm A}+{\rm C}'+{\rm BB}') \\ = ({\rm A}+{\rm B}'+{\rm C})\ ({\rm A}+{\rm B}'+{\rm C}')\ ({\rm A}+{\rm B}+{\rm C})\ ({\rm A}'+{\rm B}+{\rm C})\ ({\rm A}+{\rm B}+{\rm C}') \\ ({\rm A}+{\rm B}'+{\rm C}') \\ [{\rm using the distributive property, as X+YZ = (X+Y)(X+Z)] \\ = ({\rm A}+{\rm B}'+{\rm C})\ ({\rm A}+{\rm B}'+{\rm C}')\ ({\rm A}+{\rm B}+{\rm C})\ ({\rm A}'+{\rm B}+{\rm C})\ ({\rm A}+{\rm B}+{\rm C}') \\ [{\rm as }\ ({\rm A}+{\rm B}'+{\rm C}')\ ({\rm A}+{\rm B}'+{\rm C}') = {\rm A}+{\rm B}'+{\rm C}'] \\ \end{array}$ 

#### \*\*\*\*\*

# Karnaugh Map (K-map):

- Using Boolean algebra to simplify Boolean expressions can be difficult.
- The Karnaugh map provides a simple and straight-forward method of minimizing boolean expressions which represent combinational logic circuits.
- ✤ A Karnaugh map is a pictorial method of grouping together expressions with common factors and then eliminating unwanted variables.
- ✤ A Karnaugh map is a two-dimensional truth-table. Note that the squares are numbered so that the binary representations for the numbers of two adjacent squares differ in exactly one position.

## **Rules for Grouping together adjacent cells containing 1's:**

- Groups must contain 1, 2, 4, 8, 16 (2<sup>n</sup>) cells.
- Groups must contain only 1 (and X if don't care is allowed).
- Groups may be horizontal or vertical, but not diagonal.
- Groups should be as large as possible.
- Each cell containing a 1 must be in at least one group.
- Groups may overlap.
- Groups may wrap around the table. The leftmost cell in a row may be grouped with the rightmost cell and the top cell in a column may be grouped with the bottom cell.
- There should be as few groups as possible.

## **Obtaining Product Terms**

- If A is a variable that has value 0 in all of the squares in the grouping, then the complemented form A is in the product term. "
- If A is a variable that has value 1 in all of the squares in the grouping, then the true form A is in the product term.
- If A is a variable that has value 0 for some squares in the grouping and value 1 for others, then it is not in the product term

## The Format of K-Maps:

K-Maps of 2 Variables:



# K-Maps of 3 Variables:

Simplify the boolean function

$$F(x, y, z) = \sum (2, 3, 4, 5)$$



$$F(x, y, z) = \sum (2, 3, 4, 5) = x'y + xy'$$
  
unction  $F(x, y, z) = \sum 3, 4, 6, 7$ 

Simplify the boolean function



#### K-Maps of 4 Variables:

| <i>m</i> <sub>0</sub> | $m_1$                  | <i>m</i> <sub>3</sub>  | <i>m</i> <sub>2</sub>  |
|-----------------------|------------------------|------------------------|------------------------|
| <i>m</i> <sub>4</sub> | $m_5$                  | <i>m</i> <sub>7</sub>  | <i>m</i> 6             |
| m <sub>12</sub>       | <i>m</i> <sub>13</sub> | <i>m</i> <sub>15</sub> | <i>m</i> <sub>14</sub> |
| <i>m</i> <sub>8</sub> | <i>m</i> 9             | <i>m</i> <sub>11</sub> | <i>m</i> <sub>10</sub> |

(a)



# Simplify the boolean function

# $F(w,x, y, z) = \sum (0, 1, 2, 4, 5, 6, 8, 9, 12, 13, 14)$ (May 2011,2012, 2014,2017), (Dec 2014, Dec 2015)



 $F(w, x, y, z) = \Sigma(0, 1, 2, 4, 5, 6, 8, 9, 12, 13, 14) = y' + w'z' + xz'$ 

Simplify the Boolean function

$$F(w, x, y, z) = \Sigma(1, 3, 7, 11, 15)$$

which has the don't-care conditions

$$d(w, x, y, z) = \Sigma(0, 2, 5)$$



# Note:

# Karnaugh Maps - Rules of Simplification

The Karnaugh map uses the following rules for the simplification of expressions by *grouping* together adjacent cells containing *ones* 

• Groups may not include any cell containing a zero



• Groups may be horizontal or vertical, but not diagonal.



• Groups must contain 1, 2, 4, 8, or in general 2<sup>n</sup> cells. That is if n = 1, a group will contain two 1's since 2<sup>1</sup> = 2. If n = 2, a group will contain four 1's since 2<sup>2</sup> = 4.



• Each group should be as large as possible.



• Each cell containing a *one* must be in at least one group.



• Groups may overlap.



• There should be as few groups as possible, as long as this does not contradict any of the previous rules.



#### **Summary:**

- 1. No zeros allowed.
- 2. No diagonals.
- 3. Only power of 2 number of cells in each group.
- 4. Groups should be as large as possible.
- 5. Every one must be in at least one group.
- 6. Overlapping allowed.
- 7. Wrap around allowed.
- 8. Fewest number of groups possible.

# Don't care combination:

In certain digital systems, some input combinations never occur during the process of normal operation because those input conditions are guaranteed never to occur. Such input combinations are don't care conditions.

# **Completely specified functions:**

If a function is completely specified, it assumes the value 1 for some input combinations and the value 0 for others.

# Incompletely specified functions:

There are functions which assume the value 1 for some combinations and 0 for some other and either 0 or 1 for the remaining combinations. Such a functions are called incompletely specified .

# **Prime Implicants:**

A prime implicant is a product term obtained by combining the maximum possible number of adjacent squares in the map. If a minterm in a square is covered by only one prime implicant, that prime implicant is said to be essential.

## \*\*\*\*\*\*

# Quine-McCluskey (or) Tabulation Method

# Minimization of Logic functions: Steps:

- $\checkmark~$  A set of all prime implicants of the function must be obtained.
- ✓ From the set of prime implicants, a set of essential implicants must be determined by preparing a prime implicant chart.
- ✓ The minterm which are not covered by the essential implicants are taken into consideration and a minimum cover is obtained from thr remaining prime implicants.

# Example:

Simplify the boolean function  $F(A,B,C,D) = \sum m (1,3,6,7,8,9,10,12,14,15) + \sum m (11,13)$  using QuineMcClusky method.(May 2018, Dec 2017, Dec2016, May 2016)

| Minterms         | Binary representation | Minterms         | Binary repres | entation     |
|------------------|-----------------------|------------------|---------------|--------------|
| m <sub>1</sub>   | 0001                  | m <sub>1</sub>   | 0001          | ✓            |
| m <sub>3</sub>   | 0011                  | m <sub>8</sub>   | 1000          | ✓            |
| m <sub>6</sub>   | 0110                  | m <sub>3</sub>   | 0011          | ✓            |
| m <sub>7</sub>   | 0111                  | m <sub>6</sub>   | 0110          | ✓            |
| m <sub>8</sub>   | 1000                  | m <sub>9</sub>   | 1001          | ✓            |
| m <sub>9</sub>   | 1001                  | m <sub>10</sub>  | 1010          | ✓            |
| m <sub>10</sub>  | 1010                  | m <sub>12</sub>  | 1 1 0 0       | ✓            |
| m <sub>12</sub>  | 1100                  | m <sub>7</sub>   | 0111          | ✓            |
| m <sub>14</sub>  | 1110                  | m <sub>14</sub>  | 1110          | ✓            |
| m <sub>15</sub>  | 1111                  | dm <sub>11</sub> | 1011          | ✓            |
| dm <sub>11</sub> | 1011                  | dm <sub>13</sub> | 1101          | ✓            |
| dm <sub>13</sub> | 1101                  | m <sub>15</sub>  | 1111          | $\checkmark$ |

# Step:1

# Step:2

| Minterms | Binary representation | Minterms       | Binary representation |
|----------|-----------------------|----------------|-----------------------|
| 1, 3     | 0 0 − 1 🖌             | 1, 3, 9, 11    | -0-1                  |
| 1, 9     | -001 🗸                | 8, 9, 10, 11 🗸 | 10                    |
| 8, 9     | 100- 🗸                | 8, 10, 12, 14  | 1 — — 0               |
| 8, 10    | 10−0 ✓                |                |                       |
| 8, 12    | 1−00 ✓                | 6, 7, 14, 15 🗸 | -11-                  |
| 3, 7     | 0-11 🗸                |                |                       |
| 3, 11    | -011 🗸                | 12, 13, 14, 15 | 11                    |
| 6, 7     | 011- 🗸                |                |                       |
| 6, 14    | -110 🗸                |                |                       |
| 9, 11    | 10-1 🗸                |                |                       |
| 9, 13    | 1-01 🗸                |                |                       |
| 10, 14   | 1-10 🗸                |                |                       |
| 10, 11   | 101- 🗸                |                |                       |
| 12, 14   | 11-0 🗸                |                |                       |
| 12, 13   | 110- 🗸                |                |                       |
| 7, 15    | -111 🗸                |                |                       |
| 14, 15   | 111- 🗸                |                |                       |

# Step:3

| Prime implicants                 | Binary representation |
|----------------------------------|-----------------------|
| 1, 3, 9, 11 (B D)                | -0-1                  |
| 8, 9, 10, 11, 12, 13, 14, 15 (A) | 1                     |
| 6, 7, 14, 15 (BC)                | -11-                  |

# Step:4

| Prime<br>implicants          | m <sub>1</sub> | m <sub>3</sub> | m <sub>6</sub> | m <sub>7</sub> | m <sub>8</sub> | m <sub>9</sub> | m <sub>10</sub> | m <sub>12</sub> | m <sub>14</sub> | m <sub>15</sub> | dm <sub>11</sub> | dm <sub>13</sub> |
|------------------------------|----------------|----------------|----------------|----------------|----------------|----------------|-----------------|-----------------|-----------------|-----------------|------------------|------------------|
| 1, 3, 9, 11 (BD)             | $\odot$        | $\odot$        |                |                |                | $\odot$        |                 |                 |                 |                 | $\odot$          |                  |
| 8, 9, 10, 11, 12, 13, 14, 15 |                |                |                |                | $\odot$        | $\odot$        | $\odot$         | $\odot$         | $\odot$         | $\odot$         | $\odot$          | $\odot$          |
| 6, 7, 14, 15 (BC)            |                |                | $\odot$        | $\odot$        |                |                |                 |                 | $\odot$         | $\odot$         |                  |                  |

 $: F(A, B, C, D) = \overline{B}D + A + BC$ 

#### \*\*\*\*\*

[NOV/DEC 2021]

\* Simplify the Boolean expression, 2y +2(WZ+WZ') to minimum number of literals. [Nov/DEC-2021] xy + x(wz + wz') $= xy + x \omega (z + z') \int z + z' = 1$ = xy+xw = x(y+w)

# 1. Define Digital Systems. Give an example.

A system which is processing discrete or digital signal is called as Digital System. Digital computer is the best example of a digital system.

# 2. What is meant by (i) bit, (ii) byte, (iii) Nibble?

- (i) A binary digit is called bit.
- (ii) A group of 8 bits are called Byte
- (iii) In binary number a group of four bits called Nibble.

# 3. Define Radix.

Radix specifies the number of symbols used for the corresponding number system. .

## 4. List the number systems used in digital systems.

- i) Decimal Number system i
- ii) Binary Number system
- iii) Octal Number system
- iv) Hexadecimal Number system

# 5. Why is a hexadecimal number system called as an alpha numeric number system?

Hexadecimal number system has the base as 16 and therefore it requires 16 distinct symbols to represent the numbers. These are numerals 0 to 9 and alphabets A to F. Since both numeric digitals and alphabets are used to represent the digits in hexadecimal number system, it is called as an alphanumeric number system.

## 6. What is 1's and 2's complement?

- ✓ The 1's complement of a binary number is the number that results when we change all 1's to zeros and the zeros to ones.
- ✓ The 2's complement is the binary number that results when we add 1 to the 1's complement. It is used to represent negative numbers.

# 7. Convert Binary to hex decimal.

1011 0010 1111<sub>2</sub> = (1011) (0010) (1111)<sub>2</sub> = B 2  $F_{16}$ 

## 8. Convert hex decimal to octal.

| Hexadecimal         | Octal                      |
|---------------------|----------------------------|
| (5A8) <sub>16</sub> | = 0101 1010 1000 (Binary)  |
|                     | = 010 110 101 000 (Binary) |
| Result              | = 2650 (Octal)             |

#### 9. Convert binary to octal and vice versa with an example.

Binary to octal:

Example: 
$$100\,111\,0102 = (100)\,(111)\,(010)2 = 4\,7\,28$$

Octal to Binary:

Sol:



## **10.** Find **2**'s complement of (1001)<sub>2</sub>.

| 1001<br>0110← | number<br>1's complement |
|---------------|--------------------------|
| + 1           | add 1                    |
| 0111          |                          |

#### 11. Illustrate Diminished Radix Complement with an example?

(Dec-2009)

Given a number N in base r having n digits, the (r-1)'s complement of N, i.e., its diminished radix complement,

is defined as (m-1) - N.

The 9's complement of 546700 is 999999 - 546700 = 453299. The 9's complement of 012398 is 999999 - 012398 = 987601.

## **12. What is BCD code (8421)?**

A decimal number in BCD(8421) is the same as its equivalent binary number only when the number is between 0 and 9. A BCD number greater than 10 looks different from its equivalent binary number, even though both contain 1's and 0's. Moreover, the binary combinations 1010 through 1111 are not used and have no meaning in BCD.

# **13. BCD addition:** 184 + 576 = ?

| BCD        | 1     | 1     |      |      |
|------------|-------|-------|------|------|
|            | 0001  | 1000  | 0100 | 184  |
|            | +0101 | 0111  | 0110 | +576 |
| Binary sum | 0111  | 10000 | 1010 |      |
| Add 6      |       | 0110  | 0110 |      |
| BCD sum    | 0111  | 0110  | 0000 | 760  |

## 14. What is excess-3 code?

This code assignment is obtained from the corresponding value of 4-bit binary code after adding 3 to the given decimal digit.

**Example:** 1000 of 8421 (BCD) = 1011 in Excess-3.

# 15. What is gray code?

The gray code belongs to a class of codes called minimum change codes, in which only one bit in the code changes when moving from one code to the next.



b(1) b(2) b(3) b(4) b(5) g(1) b(1) xor g(2) b(2) xor g(3) b(3) xor g(4) b(4) xor g(5)

#### 19. What is Error detecting codes?

When data is transmitted from one point to another, like in wireless transmission, or it is just stored, like in hard disks and memories, there are chances that data may get corrupted. To detect these data errors, we use special codes, which are error detection codes.

#### 20. What is Error correcting code

Error-correcting codes not only detect errors, but also correct them. This is used normally in Satellite communication, where turn-around delay is very high as is the probability of data getting corrupt.

#### 21. What is Hamming codes?

Hamming code adds a minimum number of bits to the data transmitted in a noisy channel, to be able to correct every possible one-bit error.

It can detect (not correct) two-bit errors and cannot distinguish between 1-bit and 2bits inconsistencies. It can't - in general - detect 3(or more)-bits errors.

#### 22. What are the Two types of parity?

**-Even parity:** Checks if there is an even number of ones; if so, parity bit is zero. When the number of one's is odd then parity bit is set to 1.

**-Odd Parity:** Checks if there is an odd number of ones; if so, parity bit is zero. When the number of one's is even then parity bit is set to 1.

23. What is Parity Checker / Generator?

## (Dec 2018)

The circuit that generates the parity bit in the transmitter is called a parity generator. The circuit that checks the parity in the receiver is called a parity checker.

# 24. What is EBCDIC codes?

- > EBCDIC stands for *Extended Binary Coded Decimal Interchange*.
- For the different alphanumeric characters the code grouping in this code is different from the ASCII code. It is actually an 8-bit code and a ninth bit is added as the parity bit.

## 25. What is meant by Boolean algebra & Boolean Expression?

A system of algebra that operates on Boolean variables are called Boolean algebra.

The binary nature of Boolean algebra makes it useful for analysis, simplification and design of logic circuits are called Boolean Expression.

## 26. What are basic properties of Boolean algebra? (Dec 2016)

The basic properties of Boolean algebra are commutative property, associative property and distributive Property

#### 27. State the associative property of Boolean algebra.

The associative property of Boolean algebra states that the OR ing of several variables results in the same

regardless of the grouping of the variables. The associative property is stated as follows:

$$A+(B+C)=(A+B)+C$$
, ii).  $A(BC)=(AB)C$ 

#### 28. State the commutative property of Boolean algebra.

The commutative property states that the order in which the variables are OR ed makes no difference. The

commutative property is i). A+B=B+A ii). AB=BA

#### 29. State the distributive property of Boolean algebra.

The distributive property states that AND ing several variables and OR ing the result with a single variable

is equivalent to OR ing the single variable with each of the several variables and then AND ing the sums.

The distributive property is

i). A+BC = (A+B)(A+C) ii). A(B+C) = AB + AC

#### **30. State De Morgan's theorem. (Dec 2019)** (April/May 2011,2010,2013) Dec- 2017 ,(May 2018)

De Morgan suggested two theorems that form important part of Boolean algebra. They are

1) The complement of a product is equal to the sum of the complements.(A . B)' = A' + B'

2) The complement of a sum term is equal to the product of the complements.(A + B)' = A'B'

## **31. Define Duality Theorem.**

Duality property states that every algebraic expression deducible from the postulates of Boolean algebra remains valid if the operators and identity elements are interchanged. If the dual of an algebraic expression is desired, we simply interchange OR and AND operators and replace 1's by 0's and 0's by 1's.

## 32. List the important postulates of Boolean theorems.

The following are the important postulates of Boolean algebra:

1.1.1 = 1,0+0 = 0.2.1.0 = 0.1 = 0,0+1 = 1+0 = 1.3.0.0 = 0,1+1 = 1.

4. 1' = 0 and 0' = 1.

# 33. What is Boolean algebra?

Boolean algebra is an algebra that deals with binary variables and logic operations. A Boolean function described by an algebraic expression consists of binary variables, the constants 0 and 1, and the logic operation symbols.

#### 34. What are the two forms of Boolean expression?

The two forms of Boolean expressions are:

i). Sum of Products Form

ii).Product of Sum Form

# 35. Define Minterm & Maxterm.

#### (May 2018)

The products of Boolean expression where all possible variables appear once in complement or un complement variables are called Minterm.

A sum terms in a Boolean expression where all possible variables appear once, in complement or un omplement form are called Maxterm.

# **36. Define Product term.**

The AND function is referred to as a product. The variable in a product term can appear either in complementary or uncomplimentary form. **Example: ABC'** 

# 37. Define Sum term.

The OR function is referred to as a Sum. The variable in a sum term can appear either in complementary or uncomplimentary form. **Example:** A+B+C'

# 38. Define Sum of Product (SOP).

The logical sum of two or more logical product terms is called sum of product expression. It is basically an OR operation of AND operated variables. **Example: Y=AB+BC+CA** 

#### **39. Define Product of Sum (POS).**

The logical product of two or more logical sum terms is called product of sum expression. It is basically an AND operation of OR operated variables. **Example:** Y=(A+B).(B+C).(C+A)

# 40. What is Canonical form?

Boolean functions expressed as a sum of minterms or product of maxterms are said to be in *canonical form*.

# 41. What is Canonical SOP Expression?

The minterms whose sum defines the Boolean function are those which give the 1's of the function in a truth table.

# 42. What is Canonical POS Expression?

The Maxterms whose product defines the Boolean function are those which give the 1's of the function in a truth table.

#### 43. What is meant by karnaugh map or K-Map method?

A kamaugh map or k map is a pictorial form of truth table, in which the map diagram is made up of cells, with each cell representing one minterm or maxterm of the function. This method provides a simple straight forward procedure for minimizing Boolean function.

#### 44. Define Cell.

The smallest unit of a karnaugh map, corresponding to one rows of a truth table. The input variables are the cells coordinates and the output variable is the cells contents.

## 45. Define Pair, Quad, and Octet.

- i). Pair: A group of two adjacent cells in a karnaugh map. A pair cancels one variable in a K-Map simplification.
- ii). Quad: A group of four adjacent cells in a karnaugh map. A quad cancels two variables in a K-Map simplification.
- iii).Octet: A group of eight adjacent cells in a karnaugh map. A pair cancels three variable in a K-Map simplification.

#### 46. What are called don't care conditions?

In some logic circuits certain input conditions never occur, therefore the corresponding output never appears. In such cases the output level is not defined, it can be either high or low.

These output levels are indicated by 'X' or 'd' in the truth tables and are called don't care conditions or incompletely specified functions.

#### 47. State the limitations of karnaugh map.

- i. It is limited to six variable maps (i.e.) more than six variable involving expressions are not reduced.
- ii. The map method is restricted in its capability since they are useful for simplifying only Boolean expression represented in standard form.

## (April/May 2013)

(Dec 2017

## (May 2014)

(May 2016)

# 48. list out the advantages and disadvantages of K-map method.

# The advantages of the K-map method are:

- i). It is a fast method for simplifying expression up to four variables
- ii). It gives a visual method of logic simplification.
- iii). Prime implicants and essential prime implicants are identified fast.
- iv). Suitable for both SOP and POS forms of reduction
- v). It is more suitable for class room teachings on logic simplification.

# The disadvantages of the K-map method are:

- i). It is not suitable for computer reduction .
- ii). K-maps are not suitable when the number of variables involved exceed four
- iii). Care must be taken to fill in every cell with the relevant entry, such as a 0, 1 (or) don't care terms.

# 49. What is tabulation method?

A method involving an exhaustive tabular search method for the minimum expression to solve a Boolean equation for more variables is called as a tabulation method.

# 50. What is a prime implicant?

A prime implicant is a product term obtained by combining the maximum possible number of adjacent squares in the map. They cannot be reduced further. (Or) A prime implicant is a group of minterms which cannot be combined with any other minterm or groups.

# 51. What is an essential prime implicant?

The Essential Prime Implicant is a prime implicant in which one or more minterms are unique, it contains at least one minterm which is not contained in any other prime implicant.

# 52. List out the advantages and disadvantages of Quine-Mc Cluskeymethod? (May 2015) The advantages of Quine-Mc Cluskey method are:

i). This is suitable when the number of variables exceed four.

ii). Digital computers can be used to obtain the solution fast.

iii). Essential prime implicants, which are not evident in K-map, can be clearly seen in the final results.

# The disadvantages are:

- i). Lengthy procedure than K-map.
- ii). Requires several grouping and steps as compared to K-map.
- iii). It is much slower.
- iv). No visual identification of reduction process.
- v). The Quine Mc Cluskey method is essentially a computer reduction method.

# 53. What is a Logic gate?

Logic gates are the basic elements that make up a digital system. The electronic gate is a circuit that is able to operate on a number of binary inputs in order to perform a particular logical function.

# 54. Which gates are called as the universal gates? What are its advantages?

The NAND and NOR gates are called as the universal gates. These gates are used to perform any type of logic application.

## 55. Write the applications of gray code.

Used in telegraphy, robust communication and error detection & correction.

**56.** Show that the logical sum of all minterms of a Boolean function of 2 variables is 1 The combinations of minterms are A'B'+A'B+AB'+AB (Nov/Dec 2009)

$$=A'(B+B')+A(B+B')$$
$$=A+A'$$

57. Find the complement of the functions F1 = x'yz' + x'y'z and F2 = x(y'z' + yz). (Dec 2015) By applying De-Morgan's theorem.

$$F1' = (x'yz' + x'y'z)' = (x'yz')'(x'y'z)' = (x + y' + z)(x + y + z')$$

$$F2' = [x(y'z' + yz)]' = x' + (y'z' + yz)'$$

$$= x' + (y'z')'(yz)'$$

$$= x' + (y + z)(y' + z')$$

58. Sketch the the waveform of each inverter output in the given diagram. (Dec 2017)



59. Convert decimal 8723 to both BCD and ASCII code for ASCII an even parity bit is to be appended at left. (Dec 2019)

Decimal - 8723 BCD - 1000011100100011 ASCII- 11000011100100011

# UNIT-P

[ MAY 2019] 59. What is the largest bimovy number that can be Expressed with 14 bits? Determine the equinalent decimal and here decimal mumbers. [NOV/DEC 2021] sol: . largest Binary unber in 14 bits 14111111111111111 Dectinal :. -> 0× 2° = 4 3 Z 8  $x_{2}^{4} = 16$  $1 \times 2^{5} = 32$ 1×26 = 64 1×27 = 128 + 1×28 = 256 1×27 = 512 + 1×210 = 1024 > 1×2" = 20 18 - 1x 212 = 4096 -1 1× 213 = 8192 16,363 Hera Decimal: 00 11/11 11/11 11/11 11 FFF 3 The answer is : SFFF

[HIAY-2019]

2. Find the complement of F= Wx + yz and then show that FF=0 501: F= WX+YZ 2. complement. F'= WX+YZ = wx + yz  $F = (\overline{w} + \overline{x}) \cdot (\overline{y} + \overline{z}) ,$ show that FF=0  $= (w_{x+y_z})(\overline{w}+\overline{x}) \cdot (\overline{y}+\overline{z})$  $= (w \overline{w} x + w x \overline{x} + \overline{w} y z + \overline{x} y z) \cdot (\overline{y} + \overline{z})$ A-A=0 =  $(\overline{\omega}yz + \overline{x}yz) \cdot (\overline{y} + \overline{z})$  $= \overline{w} y \overline{y} \overline{z} + \overline{x} \overline{y} \overline{y} \overline{z} + \overline{w} \overline{y} \overline{z} \overline{z} + \overline{x} \overline{y} \overline{z} \overline{z}$ FF = '0' cunce provid · · · · • 1 - 1 - 1 - 1 A 14 C 16 1 - C., in it with a ÷ . - 1 - C - 🔅

UNIT-I NUMBER CONVERSION Problems to be discussed. Decimal to Binary \* (48,16) = ( )2 \* (48) 10 = ()2  $2 | \frac{18}{23 - 0} = 0.16 \times 2 = 0.32 \Rightarrow 0$  $2 | \frac{48}{2} | \frac{24}{-0} - 0 \\ 2 | \frac{12}{-0} - 0 \\ 2 | \frac{6}{-0} - 0 \\ 2 | \frac{3-0}{-0}$  $2 | \frac{12 - 0}{2 | 12 - 0} = 0.32 \times 2 = 0.64 \Rightarrow 0$   $2 | \frac{12 - 0}{2 | 6 - 0} = 0.64 \times 2 = 1.28 \Rightarrow 1.50$   $2 | \frac{3 - 0}{2 | - 1} = 0.28 \times 2 = 0.56 \Rightarrow 0$ ~ (48)10 = ( 110000)2 // - (48.16)10 = (110000.0010)2 / (2) Decimal to octal \* (A 0.72) = () 0.72 18 = 5.76 = 5 8 40 0.76×8 = 6.08 => 6 0.08 ×8= 0.64 > 0 0.64×8 = 5.12 = 5 -· ( 40.72) = ( 50.5605) 8 11 10 3 3) Decimal to hera decimal \* (82.15)10 = ()16 0.15×16 = 2.40 => 2 16 32  $0.40 \times 16 = 6.40 \Rightarrow 6$ 0.40 x16 = 6.40 => 6 0.40 × 16 = 6.40 = 6  $-(32.15)_{10} = (20.266)_{16}$ 

I·

(\*) Bimary to Decimal  
\* 
$$(100110 \cdot 10)_{2} = (-)_{10}$$
  
 $10 \quad 0 \quad 11 \quad 0 \quad 1x_{2} = (-)_{10}$   
 $10 \quad 0 \quad 11 \quad 0 \quad 1x_{2} = (-)_{10}$   
 $1x_{2} = (-)_{10} \quad 1x_{2} = 2$   
 $1x_{2} = (-)_{10} \quad 1x_{2} = (-)_{1$ 

(1) here defined to Binary  
\* (17B. C2)<sub>11</sub> = C2  
  

$$\frac{1}{2}$$
  $\frac{7}{4}$   $\frac{1}{4}$   $\frac{1}{4}$   $\frac{1}{4}$   $\frac{1}{4}$   
 $\frac{1}{0001}$   $\frac{1}{011}$   $\frac{1}{101}$   $\frac{1}{100}$   $\frac{1}{000}$   
(1B. C2)<sub>16</sub> = (0001 0111 1011.  $\frac{1}{100}$   $\frac{1000}{10}$   
(1B. C2)<sub>16</sub> = (0001 0111 1011.  $\frac{1}{100}$   $\frac{1000}{10}$   
\* (17 B. C2)<sub>16</sub> = C)<sub>8</sub>  
 $\frac{1}{4}$   $\frac{1}{4}$   $\frac{1}{4}$   $\frac{1}{4}$  separate the numbers.3  
 $\frac{1}{000}$   $\frac{1}{51}$   $\frac{1}{71}$   $\frac{1}{3}$   $\frac{1}{60}$   $\frac{100}{8}$   
(17 B. C2)<sub>16</sub> = (0573.  $\frac{1}{8}$ )<sub>8</sub>  
(17 B. C2)<sub>16</sub> = ( $\frac{1}{8}$ )<sub>8</sub>  
(17 B. C2)<sub>16</sub> = ( $\frac{1}{8}$   $\frac{1}{8}$ )<sub>8</sub>  
+ Heradefinal to Decimal  
\* ( $\frac{1}{18}$ . C2)<sub>16</sub> =  $\frac{1}{8}$   $\frac{1}{18}$  +  $\frac{1}{8}$   $\frac{1}{18}$  +  $\frac{1}{2}$   $\frac{1}{18}$   
 $= (18156) + (1816) + 11 + \frac{1}{128}$   $\frac{1}{18}$  +  $\frac{1}{28}$   
 $= 256 + \frac{1}{12} + 11 + 0.75 + 0.0018$   
 $= 379.7$   
 $\therefore$  ( $\frac{1}{18}$ . C<sub>2</sub>)<sub>16</sub> = ( $\frac{3}{19}$ . T)<sub>10</sub> //

(c) social fo perimal  

$$\begin{array}{c} * \quad (RM \quad (64.5)_{8} = (1_{10} \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ & & \\ &$$

Page 48 of 113

K

ONE'S COMPLEMENT REPRESENTATION :-

It the one's complement of a number is found by changing all the O's (2010's) of the world is (one's) and all the 's conies to O's (2010's).

Ex ample.

×

\* Find the one's complement of the following binary mumbers.

(1) 0 100111 001 to change the ones complement : 1011000110.

0 11011010

To change the one's complement

. 00100101.

Example:

\* Find e's complement:

1 01001110

n! unible = 0 | 00 | 1| | 0is complement = 1 0 | 1 0 0 0 | ndd + eor) = 1 0 | 1 0 0 | 0 0 | 0 Page 50 of 113 // 0 0 | 0

# ARITHMETIC OPERATION :-

struthmetic operations in a computer our done usinga brinary numbers and not decimal numbers and these take place in its arithmetic unit.

1 delition

0+0 =0

0 + 1 = 0

1+0=1

1+1 = 10

subfraction 0-0 =0

1-0=1

1-1=0

10 - 1 = 1

0=1 × 0 0 = 0 10 1×1=0  $0 \times 1 = 0$ (x0=0 1×1=1

DEMISION

101

rg netipheation



Binary Subtraction:-Example: " MSB 10, (-) 100) 0 1 0 0

|         | 2)         | 1001     |
|---------|------------|----------|
| Decunal | <b>C 1</b> | 101      |
| 43      | (-)        | 010      |
| 9       | -          | <b>1</b> |
| 4       |            |          |
|         |            |          |

| 3)  | XXXXXX | 4) | 1 1 0 - 0) |
|-----|--------|----|------------|
| (-) | 1.7    | () | 100.1      |
| v   | 1101   | -  | 1. 1.1     |

Page 53 of 113

Subtraction usual complements:  

$$\frac{1}{1000}$$
  $\frac{1}{1000}$   $\frac{1}{1000}$ 

$$\begin{array}{c} \$ 2's \quad \operatorname{Complement} \quad \operatorname{Subtraction} \\ 1 \quad \operatorname{Subtrad} \quad (10 \text{ to})_2 \quad \operatorname{From} \quad (1111)_2 \quad \operatorname{Dsing} \quad 2's \quad \operatorname{templement} \\ \begin{array}{c} sole \\ \hline \\ sole \\ \hline \\ sole \\ \hline \\ 1010 \\ \hline \\ 2's \quad \operatorname{complement} \quad \rightarrow \quad 1'+1 \\ \hline \\ 0100 \\ \hline \\ 010 \\ \hline \\ 010$$

\* (48) 0 0 1000 n=6  
(49) 0 0 1001  

$$\boxed{10} 10001$$
  
 $\boxed{10} 10001$   
 $\boxed{10} 10001$   
 $\boxed{10} 10001$   
 $\boxed{10} 10001$   
 $\boxed{10} 10001$   
 $\boxed{10} 10001$   
 $\boxed{10} 1000$   
 $\boxed{10} 8+ (-9) = -127$   
 $\boxed{10} 1111$   
 $\boxed{11} 8+ (-9) = -127$   
 $\boxed{10} 1111$   
 $\boxed{11} 8+ (-9) = -127$   
 $\boxed{10} 1001 = -127$ 

$$f = \frac{1}{2} \frac{1}{2}$$

105 conflement 8 ub fronction: Sub. 32 from 69 -At sub of from 9 .69 b -> 10's comp. of by drop (1) 37 5 dorop ON BINARY CODES. Excen-3 lode. Þ connect (6A3), to excess-3 code. 6 4 3 Add 3 to each lif. +3 +3 +3 7 6 Sum ) 9 Binovy to gray code. the gray code is. \* convert (10110)2 ナヤヤヤ (1'00) 110 0 A Gray to Brinary cock 1 0 0 1 0 1 otre binary out 1 0 0 1 1 0 (100110) 2 1 0 0 1 1 0 (100110) 2 \* convert ([ 10 (01)] Home block Prob Coms: \* convert Binary to grow ; (10101101), (1111)2 Convert Gray to Brinny, (1010111)2, (1011)2 Q. 606 Page 60 of 113



| 17. | Erplain the Potoporties of Boolean Agebra. [DEC-2015]<br>FROPERTIES OF BOOLEAN ALOIERAN. |
|-----|------------------------------------------------------------------------------------------|
|     | * <u>Commutative</u> <u>Property</u> .<br>Boolean addition às commutative is given by.   |
|     | $A+B = B+A$ , $A \cdot B = B \cdot A$                                                    |
|     | A sociative proporty:<br>The associative proporty of addition is given by,               |
| ,°  | A+CB+C) = CA+B+C                                                                         |
|     | the associative lans of multiplication is given by.                                      |
|     | $A \cdot (B \cdot c) = (A \cdot B) \cdot c$                                              |
|     | * Disfributure property:-                                                                |
|     | the boolean addition is distributive our boolean multi-                                  |
|     | - $plication$ , $A+BC = (A+B)(A+C)$                                                      |
|     | $A \cdot (B + C) = CA \cdot B + CA \cdot C)$                                             |
|     | $P_{\sigma vof} = A + BC = A \cdot 1 + BC : (A \cdot 1 = A) by T7$                       |
|     | $\Rightarrow A(1+B)+BC : (1+B)=1$                                                        |
|     | $\Rightarrow A \cdot (1+c) + AB + Bc \qquad \therefore (1+c=1)$                          |
|     | $\Rightarrow A \cdot 1 + A \cdot c + AB + BC$                                            |
| ^   | $\Rightarrow A \cdot A + AC + AB + BC : (A \cdot A = A)$                                 |
|     | $\Rightarrow A(A+C) + B(A+C)$                                                            |
|     | A+BC = (A+B)CA+C)                                                                        |
|     | hence proved.                                                                            |
|     |                                                                                          |

\* Absorption law: 
$$I \neq \bar{u}$$
 given by,  
 $J$ ,  $A + AB = A$   
Proof:  $A + AB = 3$   $A \cdot 1 \neq AB$   
 $\Rightarrow A(1+B)$   
 $\Rightarrow A - 1$  :.  $(1+B) = 1$   
 $A + AB = A$   
 $bunu proved$   
 $J$ ,  $A \cdot (B+B) = A$   
 $proof: A \cdot (A+B) = A \cdot A + AB$   
 $\Rightarrow A + AB$   $\therefore [A \cdot A = A]$   
 $\Rightarrow A (1+B)$   
 $\Rightarrow A(1)$   $\therefore [1+B = I]$   
 $A + \bar{B}B = A+B$  tunc proved  
 $J$ ,  $A \cdot (A+B) = A + \bar{A}B$   
 $\Rightarrow A(1)$   $\therefore [A \cdot I = A]$   
 $A + \bar{B}B = A+B$  tunc proved  
 $J$ ,  $A + \bar{B}B = A+B$  tunc proved  
 $J$ ,  $A + \bar{B}B = A+B$  tunc proved  
 $J$ ,  $A + \bar{B}B = A+B$  tunc proved  
 $J$ ,  $A + \bar{B}B = A + \bar{B}B = 2 (A + \bar{B})(A + B)$   $\Rightarrow (A + \bar{B}) = A + \bar{B}B$   
 $I = A + \bar{B}B = 2 (A + \bar{B})(A + B)$   $\Rightarrow (A + \bar{B})(A + B)$   
 $I = A + \bar{B}B = 2 (A + \bar{B})(A + B)$   
 $I = A + \bar{B}B = 2 (A + \bar{B})(A + B)$   
 $I = A + \bar{B}B = A + \bar{B}B$   
 $I = A + \bar{B}B = A + \bar{B}B$   
 $I = A + \bar{B}B = A + \bar{B}B$   
 $I = A + \bar{B}B = A + \bar{B}B$   
 $I = A + \bar{B}B = A + \bar{B}B$   
 $A - (\bar{A} + B) = AB$   
 $A - (\bar{A} + B) = AB$   
 $A - (\bar{A} + B) = AB$   
 $A - (\bar{A} + B) = AB$ 

\* Poinciples of Durality: one expression com be obtained prom the other in each pair by replacing every o' with ' and every I with o', every (+) with (.), and every (+). Any point of expression satisfying this property is called dual expression. This charactoristics of Boolian algebra is called principle of duality. \* Demosgonis Theo Jems!. 1) The complement of product is equal to the sum of the complement. AB = A+B 2) The complement of sum is equal to the product  $\overline{A} + \overline{B} = \overline{A} \cdot \overline{B}$ 

Proof:

|   |                       |                                 |       |         |      |                            |                                       | 1   |
|---|-----------------------|---------------------------------|-------|---------|------|----------------------------|---------------------------------------|-----|
| B | Ā                     | B                               | AtB   | A. B    | ·A+B | A.B                        | A.B                                   | A+B |
| 0 | 1                     | 1                               | 0     | 0       | 1    | 1                          | t                                     | 1   |
| 1 | 1                     | 0                               | t.    | 0       | Ø    | 0                          | 1                                     | 1   |
| 0 | 0                     | 1                               | 1     | Ø       | 0    | 6                          | T                                     | -   |
| ) | 0                     | 0                               | 1     | 1       | 0    | 0                          | 0                                     | 0   |
|   | B<br>0<br>1<br>0<br>1 | B A<br>0 1<br>1 1<br>0 0<br>1 0 | 0 1 1 | 0 1 1 0 |      | 1 0 0 1 1 0<br>0 0 1 0 1 1 | 0 1 1 0 0 1 1<br>1 1 0 1 0 0<br>0 0 0 |     |

hence proved.

Page 67 of 113

| 6)  | Simplify the expression, AB +AC + ABC (AB + C). (Dec 2017)                                                                                                                                                                                                                    |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Sol:<br>AB+AC+ ABC (AB+C) => AB+AC + ABC. AB + ABC. C                                                                                                                                                                                                                         |
| ł   | $\Rightarrow AB + \overline{AC} + A\overline{BC} \qquad [ : B - \overline{B} = 0, C - C = C ]$                                                                                                                                                                                |
| -   | $\Rightarrow AB + \overline{A} + \overline{C} + A\overline{B}C$                                                                                                                                                                                                               |
| . × | $\Rightarrow \overline{A} + \overline{AB} + \overline{C} + \overline{AB} = \begin{bmatrix} : & A + \overline{AB} \\ \downarrow & \downarrow \\ A\overline{B} \end{bmatrix} = \begin{bmatrix} : & A + \overline{AB} \\ \downarrow & \downarrow \\ A\overline{B} \end{bmatrix}$ |
|     | $\Rightarrow \overline{A} + A (B + \overline{B}) + \overline{C}$                                                                                                                                                                                                              |
| v   | $\Rightarrow \overline{A} + A(1) + \overline{C} = [B + \overline{B} = 1]$                                                                                                                                                                                                     |
|     | $\Rightarrow 1 + \tilde{c}$ $\therefore [A + \tilde{A} = 1]$                                                                                                                                                                                                                  |
|     | $\Rightarrow 1_{m}$ : $[1+\overline{c}=1]$                                                                                                                                                                                                                                    |
|     |                                                                                                                                                                                                                                                                               |
| T   | Simplify the expression,                                                                                                                                                                                                                                                      |
|     | $\overline{A\overline{b}} + ABC + A(B + A\overline{B}) \Rightarrow \overline{A(B + BC)} + A(B + A)  \therefore [B + A\overline{B} = B + A]$                                                                                                                                   |
|     | $\Rightarrow$ $A(B+OC) + AB + A \cdot A$                                                                                                                                                                                                                                      |
|     | $\Rightarrow$ $\overline{AB} + AC + AB + A$                                                                                                                                                                                                                                   |
|     | $\rightarrow \overline{AB} + AC + A(B+1)$                                                                                                                                                                                                                                     |
| 2   | C pil=1                                                                                                                                                                                                                                                                       |
|     | $ = \overline{AB} + AC + A \cdot I \qquad [: B + I = I] $ $ = \overline{AB} \cdot (AC) + A \qquad : [A + B = A + B] $                                                                                                                                                         |
|     | 3 (AB) (AC) (III)                                                                                                                                                                                                                                                             |
|     | $= \sum_{i=1}^{n} \overline{(A+B)} \cdot (A+C) = A+BC$                                                                                                                                                                                                                        |
|     | E ROT +A STLAT                                                                                                                                                                                                                                                                |
|     | CATH -                                                                                                                                                                                                                                                                        |
|     | $ \Gamma(+\chi=1)$                                                                                                                                                                                                                                                            |
|     |                                                                                                                                                                                                                                                                               |
|     | 3 O J                                                                                                                                                                                                                                                                         |
|     |                                                                                                                                                                                                                                                                               |

Page 68 of 113

Comonical SOP expression.

270

R

Problems  
1) obtain 
$$po_{3} \neq cc_{1}^{2}$$
 scenion.  
 $Y = (A + \overline{B}) (B + c) (A + \overline{c})$   
 $\Rightarrow (A + \overline{B} + c \cdot \overline{c}) (A \cdot \overline{A} + B + c) (A + B \cdot \overline{c})$   
 $\Rightarrow (A + \overline{B} + c) (A + \overline{B} + \overline{c}) (A + B + c) (A + B + c)$   
 $(A + B + c) (A + B + \overline{c}) (A + B + c) (A + B + c) (A + B + c)$   
 $Y = 2)(A + \overline{B} + c) (A + B + \overline{c}) (A + B + c) (A + B + c)$   
 $Y = 2)(A + \overline{B} + c) (A + \overline{B} + \overline{c}) (A + B + c) (A + B + c)$   
 $Y = 2)(A + \overline{B} + c) (A + \overline{B} + \overline{c}) (A + B + c) (A + B + c)$   
 $Y = A + \overline{B} c \Rightarrow A (B + \overline{B}) (c + \overline{c}) + (A + \overline{A}) \overline{B} c$   
 $\Rightarrow (A + B - \overline{c}) (A + B - \overline{c}) + (A + \overline{A}) \overline{B} c$   
 $\Rightarrow (A + B - \overline{c}) (A + B - \overline{c}) + (A + \overline{A}) \overline{B} c$   
 $\Rightarrow (A + B - \overline{c}) (A + B - \overline{c}) + (A + \overline{A}) \overline{B} c$   
 $\Rightarrow (A + B - A - B - \overline{c}) + (A + \overline{A}) \overline{B} c$   
 $\Rightarrow (A + B - A - B - \overline{c}) + (A + \overline{A}) - (A - \overline{B}) - (A - \overline$ 

KAENAUGH MAP :-



Page 73 of 113



Page 74 of 113

74

5)



Preck lews:  
1) NJ twinning the following Beoleon expressions using R-mov.  
1) 
$$\forall (A,B,C,D) = AB + CB + C$$
  
1)  $\forall (A,B,C,D) = AB + CB + C$   
2)  $\forall (A,B,C,D) = AB + CB + C$   
3)  $AB(C+D) + (A+B)CB + (A+B)(B+B)C$   
3)  $AB(C+ABC + ABC + BCC + ABC + AB$ 

$$\begin{cases} Variable t - map (P o.s) \\ F(A | B | c) = Trn (A | S | b, 7, 0, 1) \\ n Re File  $\frac{B + C}{O + O} = \frac{B + C}{O + O} = \frac{F}{P + C} \\ \frac{B}{S + O} = \frac{B + C}{O + O + O} = \frac{F}{O + O} =$$$

$$\begin{array}{c} p_{n,1} + correction constraints} \\ p_{n,1} + correction constraints} \\ p_{n,2} + correction constraints} \\ p_{n,2} + correction constraints} \\ p_{n,3} + p_{n,2} + correction constraints} \\ p_{n,3} + p_{n,3} p_{n,$$

1

r

|                      |             |                |       | , p      | 1 -      |        | is doir for   |
|----------------------|-------------|----------------|-------|----------|----------|--------|---------------|
| A Baine - Mcc        | hisky 6     | in Tabulat     | on    | nge thou | d · of   | anan   | n Cequit - 0" |
| 1) Find the m        | inimal      | sop for the    | Boo   | Cean e   | ep russi | 010 -  |               |
| $f = \mathcal{E}(t)$ | 2, 3, 7, 8  | 9,10,11,14,15) | *     | EMAX     | 2013,    | 15,17  | (Dec 2019)    |
| sol                  |             |                |       |          | •        | [NOV 2 | 020]          |
| at Binary Rep.       | es entation | of Agin Pourus |       | r        |          |        |               |
| oria                 | n ferm      | A B C D        |       |          |          |        |               |
|                      | 1           | 00 00          |       |          | 4        |        |               |
|                      | 3           |                |       |          |          |        |               |
|                      | 9           |                | )     |          |          |        | \             |
|                      | 10 <u> </u> |                | 0     |          |          | 242    |               |
|                      | 14          |                | 0     |          |          |        | 5<br>1        |
| of Q showy of m      | - forman    | Pour datterra  | F ADA | ranhe?   | Ø        | 1-6    |               |
|                      |             |                |       | orara    |          | ,<br>  |               |
|                      | o. \$ 15    | Mintam         | A     | B        | C        | D      |               |
|                      | ٢           | 1<br>2         | 0     | 0        | 0        | 70     |               |
|                      |             | 8              | 1     | 0        | o        | 0      |               |
|                      | 2           | 3              | 0     | 0        | 1        | 15     |               |
|                      |             | 10             |       | 0        | 0        | 0      |               |
|                      | 3           |                |       | 1        | )        | )      |               |
|                      |             | 14 1           |       | 0        | t        | Ö      |               |
|                      | 4           | 15 1           |       | ,        | 1.       | 1      |               |

Page 80 of 113

\*

2. cell combination:-

| 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - 1 - |    |    |                |     | + |
|-----------------------------------------|----|----|----------------|-----|---|
| combination                             | A  | B  | C              | D   |   |
| (1,3)                                   | 0  | 0  | -              | 1   |   |
| (1,9)                                   | -  | 0  | 0              | 1   |   |
| (2,3)                                   | 0  | 0  | 1.77           | 2   |   |
| (2,10)                                  | _  | 0  | 1              | 0   |   |
| (8,9)                                   | 1  | 0  | 0              |     | _ |
| (00,8)                                  | 1  | 0  | -              |     | σ |
| (8,7)                                   | 0  | -  | 1              |     | 1 |
| (3+11)                                  |    | O  | 1.1            | · . | 1 |
| (9,11)                                  | 1  | 0. |                |     | 1 |
| (11101)                                 | 1  | Q  | J.             |     | - |
| C10,14)                                 | 1  | -  |                | 1   | 0 |
| (7,15)                                  | -  | 1  |                | 1   | ) |
| C11,15)                                 | 1. |    |                | 1   | 1 |
| (14,15)                                 | 1  | 1  | , <sup>1</sup> | 1   | - |

\*

A- cell combination.

| Combinnation.    | A   | B | C | D |
|------------------|-----|---|---|---|
| (1,3,9,11)       |     | 0 | - | 1 |
| (2,3,10,11)      | _   | 0 | I |   |
| (8,9,10,11)      | ٢   | Ø | - | - |
| (8,7,11,15)      | -   |   | 1 | ) |
| C10, 11, 14, 15) | t i | - | 1 | _ |

\* Prouve Emplicants Table:

Mintours Prime Emplicants. ١ 2 3 7 8 9 10 11 14 15 (1,3,9,11)\* × X × x (2,3, (0,1))\* x ٨ x (8,9,10,1) x x x K (3,7,11,15) x X x x (10,11, 14,15 × × x X ANSWER: Y= BD+BC+CD+AB+ACP Find the minimal sop for the Boo learn expression. & (AIBICID) = Sm (011,2,5,6,7,8,9,10,14) [MAR 2017]. Binary Representation of Mintouns. min Terry noriable. B CD. A 00 0 0 0 1 0 0 0) 2 0 0 1 0 5 0 01 6 0 011 7 C 11 8 ) 000 9 1 001 Ø 1 0 10 14 10

group of mintans of diff. no. of is.

| No of | Minterm | [ | ind | riabl | Ľ |
|-------|---------|---|-----|-------|---|
| ' دم  |         | A | B   | C     | D |
| 0     | Ø       | Ø | Ø   | Ø     | 0 |
| 1     | 1       | 0 | O   | O     | 1 |
|       | 2       | 0 | Ø   | 1     | 0 |
|       | 8       | 1 | Ø   | O     | Ô |
| 2     | 5       | O | 1   | Ø     | T |
|       | 6       | 0 | f   | ١     | 0 |
|       | 9       | Ŧ | 0   | 0     | 1 |
|       | UO      | 1 | Ø   | t     | 0 |
| 3     | 7       | 0 | 1   | t     | , |
|       | 14      | ١ | t   | )     | 0 |
|       |         |   |     |       |   |

\*

2

- cell combination:

com bination. B A c D (0,1)~ O O Ø ----(012) ~ O С O \_\_\_\_ (018)~ O O 0 C1,5) 0 Ø 1 \_ (119)~ 0 0 1 -(2, b)~ 0 0 I (2100)~ 0. O 1 ~(818)~ ١ 0 O (3,10) 1. 0 0 (5,7) 0 1 1 (617) 0 ł (6,4) Page 83 of 113 (10,14)l.

\* 4- cell combination."-

| ., |                    |       |      |     |     |   |     |     |    |     |
|----|--------------------|-------|------|-----|-----|---|-----|-----|----|-----|
|    | combination        | A     | B    |     | C   |   | D   |     |    |     |
| 2  | (0111819)          |       | 0    |     | 0   |   | _   |     |    |     |
|    | (0,2,8,00)         | -     | 6    |     |     |   | 0   |     |    |     |
|    | (0,1,9,0)          |       | Ô    |     | 0   |   |     |     |    |     |
|    | (0, 18, 2, 10)     | -     | 0    |     | -   |   | 0   | a.  | _  |     |
|    | 2 July 1 - 2 miles | 1     |      |     |     |   |     |     | _  |     |
|    | (216,10,1M)        | -     | -    |     | • J |   | O   |     |    |     |
|    | (2,10,6,14)        |       | _    |     | 1   |   | 0   |     |    |     |
|    |                    |       |      |     |     |   |     |     |    |     |
| *  | Prime Emplicant Te | able. |      | Min | For |   |     | 1   |    |     |
|    |                    |       | .1.1 |     | Í   |   |     |     |    |     |
|    | Portune Emptican   | vti o | 1-2  | 5   | 6   | 7 | 8   | 9   | 10 | 14  |
|    | Co11,8,9)*         | *     | x    | 7   | •   |   | ĸ   | κ.  | 15 |     |
|    | (01218100)         | ×     | *    |     |     | - | X   |     | ×  |     |
|    | (01811,9)          | × -   | x    |     | _   |   | R   | ĸ   |    | tan |
|    | (018,2,10)         | ×     | ×    |     |     | - | R   | in. | ĸ  |     |
|    | (2,6,10,14)        | ĸ     | ×    |     | x   |   |     | 1   | ר  | Χ.  |
|    | (2,10,6,14         |       | X    |     | X   |   |     | 1   | ×  | x   |
|    |                    |       | Ivi  |     | V   |   | l - | Ir  | 1  |     |
|    |                    |       |      |     |     |   |     |     |    |     |

25

22)

Prince Sup Front Falle. Min ferms Prime Emphiants. 1 2 5 0 8 6 q 139 10 (0, 1, 8, 9)X r x x (0,2, 8,00) 72 X R X (2,6,10,14) x X × R (1,5) R x (5,7) X X (6,1) x x ABD+CD+BC Y= The following 5 nariable Boolean expression wing Simp lify [DEC-2014, 2016] method Mcchisky F= Em (0,1,9,15,24,29,30)+d (8+11,31) Sol. Bimary Representation. minform 00000 00001 01001 11:11 O 15 1000 24 101 27 110 30 01000 dø 0101) di (111) Page 85 of 113 85 d31

BCDE. A Minfer No. of is 0 0 -0 Ø 0 0 0 1--١ 0 000 8 / 000 C t 9 2 ſ 001 O 29 000 1 1 11 0 1 O 3 1) 1 O t 1 15 ) 4 29 01 1 1 30 10 ţ 1 1 ľ 5 31 1 1 Ì 2 cell combination. A At A ceal constitution combi ABCDE. combination ABCDE (0,1) 0 0 0 0 \_ (018,1,9) O-00-C(8,0) 0 - 0 0 0 E1,9)~ 0 \_ 001 (8,24) 1 000 (9,11) 10 - 10 (11,15) 1-11 0 (15731) \_ 1 111 · 111-) (29131) 111-(30131) 1

of Prime Emplication Dable.



F>> BEDE + ABDE + BODE + ABCE + ABCD + AED

Con Vent AND TO NAND CROTE". 1) draws the AOS logit AB 2-) odd babble on ip of okgate )o- Do-AB to p side of AND gate. 3) Add on inverter on each line that received bubble Csteps A. Convert OR gorte to Nok gate. 4) Eliminate double inversions T) prous all Nonto symbols At D p drans Ao & logic. ATE LO (A+B) 2) Add babble isp of AND gale solv of or gate. A+B Do-8) After subtract one inverter. c receives babble) A) draw all NOR symbols. Problems : 1) draw the lope circuit using gate. F=A+B+CD+BC. 50 F= AB+CD+BC.



that received bubble. Add in verters on each time stop 3: . B -,Do----10-10-\_`y step n' É l'iminate double inversions. -00с.\_\_\_\_ 0 P ..... styp5: - Rep bee by NAND gates s to lo por spi in a spi home block Emplement ening NAND gates, N= CAAB+E) DHEF The state of a state of a state allow here is Page 90 of 113 · 1



drovo Nor diagrom. steps 1114 home Talorki. Anyr & ment . Phe boo hom expression using only NOR gates. Y=[(A+B)Z+D](E+F) and provide all and down activity khat itself Andrews and the standard the 92 Page 92 of 113

#### [NOV 2020]

100

[DEC 2018] 1

Jur (Decoral \* Find the Msop Representation Br F(A, B, C, D, E) = Em (1, 4, 6, 10, 20, 22, 24, 26) + Ed (0, 11, 16, 27) using K-map. Draw the circuit of the minimal expression using NAND gates.



F(AIBICIDIE) = ABCD+BCE+BCD+ABCE

A=1





May 2019

# Determine the MSOP of BOOLEON expression. [DEC. 2018] P(A,B,C,D) = Em (1,2,3,7,12,13,14) + 2d (0,7,10,15) using Quince Mc-cluskey wethod.

Skp1: Bit Representation.

|          | 1            |     |   |          |        |
|----------|--------------|-----|---|----------|--------|
| Minterms | ٨            | B   | e | ÞF       | 1      |
| · 7      | Ø            | 0   | 0 | 1        | 12     |
| 2        | Ø            | 0   | 1 | 0        | 1      |
| 3        | 0            | 0   | 1 | )        |        |
| 9        | 1            | O   | 0 | )        |        |
| 12       | 1-           | 1   | 0 | 0        |        |
| 13       | 1 -          | 1   | 0 | )        |        |
| 14       | 1.5          | 1   | 1 | 0        |        |
| do       | 0 -          | 0   | O | 0        |        |
| dy       | 0            | L,  | ) | 1-1-1    |        |
| dro -    | 10           | 0   | Ţ | <b>0</b> |        |
| d 15     | . <b>)</b> t | N y | ? | lane     |        |
|          | 1            |     | 1 |          | 17 / C |

Step 2. ?. R'cell Combination.

CD. ß Ð mintouns 0 0 0 0 0 0 1 14 0 0 0 10 ... 1 0 O 0 0 1 ١ 3 V O ſ 2 · O 0 0 dio O

First st

| ع  | mintours | Ð       | \$     | c        | P |
|----|----------|---------|--------|----------|---|
|    | 13       | 1 211 2 | A . 81 | 0        | 1 |
|    | 737      |         | 1      | . Sol    | 0 |
| N. | 94       | 0       | Ĵ      | )        | , |
| 4  | d 15-    | 1       | 1      | 1        | , |
| I  | 1        | 4       | 6      | 4 1<br>1 |   |

steps: 2 cell Combination

| Accel     | ·w       | aria | ble.    | D.                | _          |
|-----------|----------|------|---------|-------------------|------------|
| i i       | A        | B    | C       | D                 | -          |
| (0,1)~··· | 0        | 0    | 0       |                   | -          |
| (0,2)     | Ø        | 0    | -       | 0                 | 1          |
| (1,3)~    | Ö        | 0    | -       | 14                | 1          |
| C1,9)     | -        | 0    | Ø       | , sk              | [          |
| (213)~    | Ó        | O    | ł       | 1-3               | ·          |
| C·2+10) 0 | <u> </u> | 0    | +       | 0 *               | <i>.</i> , |
| C13,15)   | 1        | )    | -       | 1                 |            |
| (1A,15)   | ١        | 1    | )       | · · · · · · · · · |            |
| (साराग्य  | <b>-</b> | - 19 | , T .). | $1_{\odot}$       |            |

8 kp 4: 4

tornel.

| A-cel     | variable, |
|-----------|-----------|
|           | ABCD      |
| (01) 213) | 0 0       |
| ¢.        |           |

ST .

| Acell                                                      |     |   |   |   | m  | interms |    |   |           |
|------------------------------------------------------------|-----|---|---|---|----|---------|----|---|-----------|
| (0,1,2,3)~                                                 | - 1 | 2 | 3 | 9 | 12 | 13,     | 14 | 0 | <br>10 15 |
| -                                                          | ×   | × | Х | ~ |    | ·       |    | × |           |
| C119)~                                                     | ×   |   |   | X |    |         |    |   |           |
| (119)<br>(2,10)<br>(13,15)<br>(14,15)<br>(14,15)<br>(7,15) |     |   | ÷ |   |    |         |    |   |           |
| (13, 15)                                                   |     |   |   |   |    |         |    |   |           |
| (14,15)~                                                   |     |   |   |   |    |         |    |   |           |
| (7,15)                                                     |     |   |   | - | •  |         |    |   |           |
| 12                                                         |     |   |   |   |    |         |    |   |           |

Step 5: " Preimary Lay Woonst Fable.

 $F = C\overline{A}\overline{B} + \overline{B}\overline{C}\overline{D} + \overline{A}\overline{B}\overline{D} + ABD + ABC + BCD + ABCD +$ 

SOLVED EXAMPLES

**Example 1.52** Implement the following Boolean function with NAND-NAND logic  $F = AB + ABC + \overline{ABC} + A\overline{B} + D$  (using only NAND gates). **Solution:** 

Step 1: Simplify the given Boolean function to get minimum number of literals.

$$F = AB + ABC + \overline{ABC} + A\overline{B} + D$$
  
= AB + BC (A + A) + AB + D [A + A = 1]  
= A (B + B) + BC (A + A) + D  
F = A + BC + D

Step 2: Draw the AND-OR logic gate



Step 3: Convert AND-OR logic to NAND-NAND logic



**Example 1.53** Implement the following Boolean function with NAND-NAND logic  $F = (A, B, C) = \Sigma m (0, 1, 3, 5, 6, 7)$  (using only NAND gates).

### © Solution:

Step 1: Simplify the given Boolean function.



 $F = C + \overline{AB} + AB = AB + \overline{AB} + C$ 





Step 3: Convert AND-OR logic to NAND-NAND logic.



## 1.7.2. NOR-NOR IMPLEMENTATION

The implementation of a Boolean function with NOR-NOR logic requires that the function to be simplified in the product of sum (POS) form.

Lets consider POS form (OR-AND logic) and how it will be represented in NOR-NOR logic.

Consider the Boolean function Y = (A + B + C) (D + E) F

# OR-AND Logic Gate



#### **NOR-NOR Implementation**



## Procedure for obtaining NOR-NOR Logic Diagram

- 1. Simplify the given Boolean function and express it in POS form.
- 2. Draw a NOR gate for each sum term of the function.
- 3. If Boolean function includes any single literal, draw NOR gate for each single literal.
- 4. Draw a single NOR gate in the second level, with inputs coming from outputs of first level gates.

# SOLVED EXAMPLES

**Example 1.54** Implement the following Boolean function with only NOR gates.

$$Y = AC + BC + AB + D$$

# © Solution:

Step 1: Here the given function is in SOP format. So first we convert it into POS form, using duality theorem, we get



**Example 1.55** Implement the following Boolean function with NOR-NOR  $log^{ic}$  (using only NOR gates)  $F = (\overline{A} + B) C$ .

TRUE LE

THE ST.

# Solution:

Step 1: Implement Boolean function with OR-AND logic.



Step 2: Convert OR-AND logic to NOR-NOR logic.



**Example 1.56** Simplify and implement the following POS function using NOR gates (Dec 2019)  $(A, B, C, D) = \Pi M (0, 1, 2, 3, 12, 13, 14, 15).$ 

© Solution:

Step 1: Simplify the given Boolean function.



Page 102 of 113

# Step 2: Implement Boolean function with OR-AND logic.



Step 3: Convert OR-AND logic to NOR-NOR logic.



**Example 1.57** Simplify and implement the following SOP function using NOR gates. (Dec 2019)

 $f(A, B, C, D) = \Sigma m (0, 1, 4, 5, 10, 11, 14, 15)$ 

Solution:

Step 1: Given function is SOP, so convert into its equivalent POS function.

 $\therefore \Sigma m (0, 1, 4, 5, 10, 11, 14, 15) = \Pi M (2, 3, 6, 7, 8, 9, 12, 13)$ 

Step 2: Simplify the given Boolean function using K-Map simplification.



11 18.42









| *) Determine all the prime implicants of the                                              |
|-------------------------------------------------------------------------------------------|
| function f(a, b, c, d) = Im(0,2,3,4,8,10,12,13,14)                                        |
| using Quine-Mc Cluskey method. Verity the                                                 |
| using Quine-McCluskey method. Verity the<br>Same wring k-map Technique.<br>[Nov/DEC-2021] |
| "Same wring ~ [Nov/DEC-2021]                                                              |

| Min terms | Variable<br>A B C D |
|-----------|---------------------|
| 0         | 0 0 0 0             |
| 2         | 0 0 1 0             |
| 8         | 0 0 1 1             |
| 4         | 0 1 0 0             |
| 8         | 1 0 0 0             |
| 10        |                     |
| 12        | 1 1 0 0             |
| 13        | 1 1 0 1             |

Step:2 Group of Minterms of different number of is

| No. of i's | Nin terms | Variable<br>ABCD |
|------------|-----------|------------------|
| 0          | 0         | 0000             |
| 1          | 2         | 0010             |
|            | 4         | 0100             |
|            | 8         | 1000             |
| 2          | 3         | 0 0 1 1          |
|            | 10        | 1010             |
|            | 12        | 1100             |
| 3          | 13        | 1 1 0 1          |
|            | 14        | 1110             |

| 014.3 |
|-------|
|-------|

2- Cell Combination

| r           |   |   |     |     |   |
|-------------|---|---|-----|-----|---|
| Combination |   | A | B   | C   | D |
| (0,2)       |   | 0 | 0   |     | 0 |
| (0, 4)      |   | 0 | -7  | O   | 0 |
| (0,8)       |   | _ | 0   | 0   | 0 |
| (2,3)       | e | 0 | 0   |     |   |
| (2,10)      | - | - | D   | - 1 | 0 |
| (4,12)      |   |   | 1   | 0   | 0 |
| (8, 10)     | 1 |   | 0   |     | 0 |
| (8,12)      | 1 |   | -   | 0   | 0 |
|             | 1 |   |     | 0   |   |
| (10,14)     | 1 |   | _   | 1   | 0 |
| (12,13)     | 1 |   | 1   | 0   | - |
| (12,14)     | 1 |   | 1 - |     | 0 |
|             | ` |   |     |     |   |
|             |   |   |     |     | 1 |

Step:4 4- Cell Combination

| - | ) | В  | С   | D     |
|---|---|----|-----|-------|
| - |   | 0  | -   | 0     |
| 1 |   | 1. | 0   | 0     |
| 1 |   | _  | -   | 0     |
|   |   |    | - 0 | - 0 - |

Step:5 Prime Implicant table

|                     | - | 4 | 121 |   |   | 2  |    |    |    |
|---------------------|---|---|-----|---|---|----|----|----|----|
| Prime Implicants    | 0 | 2 | 3   | 4 | 8 | 10 | 12 | 13 | 14 |
| (0, 8, 2, 10)<br>BD | * | * |     |   | * | *  |    |    |    |
| (0,8,4,12) ED       | * |   |     | * | * |    | *  |    |    |
| (8, 12, 10, 14) AD  |   |   |     |   | * | *  | *  |    | *  |
| (2,3)* ABC          |   | × | *   |   |   |    |    |    |    |
| (12,13) ABE         |   |   |     |   |   |    | *  | *  |    |
| 4.5 m               |   |   | V   | 1 |   |    |    |    |    |

:. The output expression is,

 $f(a, b, c, d) = \overline{ABC} + \overline{CD} + ABC + \overline{AD}$ 

- K- Map :-



 $f(a, b, c, d) = \overline{ABC} + \overline{CD} + ABC + AD$ 

\*) With the use of maps; find the Simplest Sum-of-Products form of the Sunction F=fg where f = abc' + c'd + a'cd' + b'cd' and g = (a+b+c'+d')(b'+c'+d)(a'+c+d')[Nov/pec-202] g = (a+b+c'+d')(b'+c'+d)(a'+c+d') = (a+b+c'+d')(aa'+b'+c'+d)(a'+bb'+c+d')(By distributive property) g = (a+b+c'+d')(a+b'+c'+d)(a'+b+c'+d)

 $g = (a'b'cd')(a'tb'+c+d') \longrightarrow O[Pos]$  g = (a'b'cd) + (a'bcd') + (abcd') + (abcd') + (abcd') + (abcd) + (abcd)

$$\begin{aligned} f &= a bc' + c'd + a'cd' + b'cd' \\ &= [a bc'(d+d'] + [a+a')(b+b')c'd] \\ &+ [a'cd'(b+b'] + [a+a')b'cd'] \end{aligned} \\ &= a bc'd + a bc'd' + a bc'd + a b'cd' + a'bc'd + a'bcd' + a'bcd' + a'bcd' + a'bcd' + a'bc'd + a'b$$

F = (a' + b' + c + d') (a' + b' + c + d) (a' + b + c + d')[a+6'+c+d') (a+6+c+d') (a+6+c+d) (a+b+c'+d) (a+b+c'+d) (a+b+c'+d')  $(a+b+c+d) \rightarrow (5) [Pos]$ 

SOP F = (abc'd) + (abc'd') + (abc'd) + (abc'd) + (abc'd)+ (a'bcd) + (a'bcd') + (a'bcd') + (abcd') + (a'b'cd) + (a bcd') 001  $= m_{13} + m_{12} + m_{g} + m_{5} + m_{1} + m_{6} + m_{2} + m_{10}$ + m3 + m14  $= \leq m(1, 2, 3, 5, 69, 10, 13, 14)$  $F = \leq m(1, 2, 3, 5, 6, 9, 10, 12, 13, 14)$ ab led K-Map 00 01 11 10 SOP F= c'd+ cd' + abc'+ abc'

## UNIT II COMBINATIONAL LOGIC CIRCUITS

Problem formulation and design of combinational circuits - Code-Converters, Half and Full Adders, Binary Parallel Adder – Carry look ahead Adder, BCD Adder, Magnitude Comparator, Decoder, Encoder, Priority Encoder, Mux/Demux, Case study: Digital trans-receiver / 8 bit Arithmetic and logic unit, Parity Generator/Checker, Seven Segment display decoder

# **COMBINATIONAL CIRCUITS**

✤ The digital system consists of two types of circuits, namely

(i) Combinational circuits and

(ii) Sequential circuits

# Combinational circuits

- ✤ A combinational circuit consists of logic gates whose outputs at any time are determined from only the present combination of inputs without regard to previous inputs or previous state of outputs..
- ✤ A combinational circuit performs an operation that can be specified logically by a set of Boolean functions.



# Sequential circuits:

- Sequential circuits contain logic gates as well as memory cells. Their outputs depend on the present inputs and also on the states of memory elements.
- Since the outputs of sequential circuits depend not only on the present inputs but also on past inputs.
- The circuit behavior must be specified by a time sequence of inputs and memory states.

\*\*\*\*\*

# **DESIGN PROCEDURE**

# Explain the procedure involved in designing combinational circuits.

Any combinational circuit can be designed by the following steps of design procedure.

- 1. The problem is stated.
- 2. Identify the input variables and output functions.
- 3. The input and output variables are assigned letter symbols.
- 4. The truth table is prepared that completely defines the relationship between the input variables and output functions.
- 5. The simplified Boolean expression is obtained by any method of minimization algebraic method, Karnaugh map method, or tabulation method.
- 6. A logic diagram is realized from the simplified expression using logic gates.

\*\*\*\*\*\*\*

(May 2015)

# HALF ADDER

Construct a half adder with necessary diagrams.

- A half-adder is an arithmetic circuit block that can be used to add two bits and produce two outputs such as SUM and CARRY.
- ✤ The Boolean expressions for the SUM and CARRY outputs are given by the equations

$$S=A'B + AB'$$
  
 $C=AB$ 

**Truth Table:** 

| Input variables |   | Output a | variables |
|-----------------|---|----------|-----------|
| Α               | В | S        | C         |
| 0               | 0 | 0        | 0         |
| 0               | 1 | 1        | 0         |
| 1               | 0 | 1        | 0         |
| 1               | 1 | 0        | 1         |



- \* The outputs S and C functions are similar to Exclusive-OR and AND functions respectively.
- Below Figure shows the logic diagram to implement the half-adder circuit.

**Logic Diagram:** 

Half adder using NAND gate:

Symbol:



# FULL ADDER

\*\*\*\*\*\*

Design a full adder using NAND and NOR gates respectively.

(Nov -10)

- ✤ A Full-adder is an arithmetic circuit block that can be used to add three bits and produce two outputs such as SUM and CARRY.
- Let us consider the input variables augend as A, addend as B, and previous carry as X, and outputs sum as S and carry as C.
- ♦ As there are three input variables, eight different input combinations are possible.

(Nov-06,May- 07)

## Truth table:

|   | Input variables | Outputs |   |   |
|---|-----------------|---------|---|---|
| X | A               | В       | S | С |
| 0 | 0               | 0       | 0 | 0 |
| 0 | 0               | 1       | 1 | 0 |
| 0 | 1               | 0       | 1 | 0 |
| 0 | 1               | 1       | 0 | 1 |
| 1 | 0               | 0       | 1 | 0 |
| 1 | 0               | 1       | 0 | 1 |
| 1 | 1               | 0       | 0 | 1 |
| 1 | 1               | 1       | 1 | 1 |

# Karnaugh map:





K-Map for Sum



The simplified Boolean expressions of the outputs are

S = X'A'B + X'AB' + XA'B' + XABC = AB + BX + AX

Logic diagram:



✤ The Boolean expressions of S and C are modified as follows

$$S = X'A'B + X'AB' + XA'B' + XAB$$
  
= X' (A'B + AB') + X (A'B' + AB)  
= X' (A  $\oplus$  B) + X (A  $\oplus$  B)'  
= X  $\oplus$  A  $\oplus$  B  
C = AB + BX + AX = AB + X (A + B)  
= AB + X (AB + AB' + AB + A'B)  
= AB + X (AB + AB' + A'B)  
= AB + XAB + X (AB' + A'B)  
= AB + X (A  $\oplus$  B)

#### Full adder using Two half adder:

✤ Logic diagram according to the modified expression is shown Figure.



### HALF SUBTRACTOR

Design a half subtractor circuit.

(Nov-2009)

✤ A half-subtractor is a combinational circuit that can be used to subtract one binary digit from another to produce a DIFFERENCE output and a BORROW output.

Truth table:

| Input variables |   | Output v | ariables |
|-----------------|---|----------|----------|
| X               | Y | D        | В        |
| 0               | 0 | 0        | 0        |
| 0               | 1 | 1        | 1        |
| 1               | 0 | 1        | 0        |
| 1               | 1 | 0        | 0        |

\* *Boolean expressions* of the outputs D and B functions can be written as

$$D = X'Y + XY$$
$$B = X'Y$$

## Logic diagram:

✤ Figure shows the logic diagram to realize the half-subtractor circuit\



# FULL SUBTRACTOR

# Design a full subtractor.

### (*Nov-2009,07*)

A combinational circuit of full-subtractor performs the operation of subtraction of three bits such as the minuend, subtrahend, and borrow generated from the subtraction operation of previous significant digits and produces the outputs difference and borrow.

# Truth table:

|   | Input variabl | es | Out | puts |
|---|---------------|----|-----|------|
| X | Y             | Ζ  | D   | В    |
| 0 | 0             | 0  | 0   | 0    |
| 0 | 0             | 1  | 1   | 1    |
| 0 | 1             | 0  | 1   | 1    |
| 0 | 1             | 1  | 0   | 1    |
| 1 | 0             | 0  | 1   | 0    |
| 1 | 0             | 1  | 0   | 0    |
| 1 | 1             | 0  | 0   | 0    |
| 1 | 1             | 1  | 1   | 1    |

# Karnaugh map:



K-Map for D

K-Map for B

The simplified *Boolean expressions* of the outputs are

S = X'Y'Z + X'YZ' + XY'Z' + XYZC = X'Z + X'Y + YZ

Logic diagram:



- ✤ The Boolean expressions of D and B are modified as follows
  - D = X'Y'Z + X'YZ' + XY'Z' + XYZ= X' (Y'Z + YZ') + X (Y'Z' + YZ) = X' (Y $\oplus$ Z) + X (Y $\oplus$ Z)' = X $\oplus$ Y $\oplus$ Z B = X'Z + X'Y +YZ = X'Y + Z (X' + Y) = X'Y + Z(X'Y + X'Y' + XY + X'Y) = X'Y + Z(X'Y + X'Y' + XY) = X'Y + X'YZ + Z(X'Y' + XY) = X'Y + Z(X $\oplus$ Y)'
- ✤ Logic diagram according to the modified expression is shown Figure.



# PARALLEL BINARY ADDER: (RIPPLE CARRY ADDER)

Explain about four bit adder with neat diagram.

- Two binary bits can be added and the addition of two binary bits with a carry.
- In practical situations it is required to add two data each containing more than one bit.
- Two binary numbers each of n bits can be added by means of a full adder circuit.
- Consider the example that two 4-bit binary numbers B<sub>4</sub> B<sub>3</sub> B<sub>2</sub> B<sub>1</sub> and A<sub>4</sub> A<sub>3</sub> A<sub>2</sub> A<sub>1</sub> are to be added with a carry input C1.
- ✤ This can be done by cascading four full adder circuits as shown in Figure.
- The least significant bits  $A_1$ ,  $B_1$ , and  $C_1$  are added to the produce sum output  $S_1$  and carry output  $C_2$ .
- Carry output  $C_2$  is then added to the next significant bits  $A_2$  and  $B_2$  producing sum output  $S_2$  and carry output  $C_3$ .
- $C_3$  is then added to  $A_3$  and  $B_3$  and so on. Thus finally producing the four-bit sum output  $S_4 S_3 S_2 S_1$  and final carry output  $C_{out}$ .
- Such type of four-bit binary adder is commercially available in an IC package.



Fig: 4 bit adder

- For the addition of two n bits of data, n numbers of full adders can be cascaded as demonstrated in figure .
- ✤ It can be constructed with 4-bit, 2-bit, and 1-bit full adder IC packages.
- The carry output of one package must be connected to the carry input of the next higher order bit IC package of higher order bits.
- The addition technique adopted here is a parallel type as all the bit addition operations are performed in parallel. Therefore, this type of adder is called a parallel adder.
- ✤ The 4-bit parallel binary adder IC package is useful to develop combinational circuits.

\*\*\*\*\*\*

# PARALLEL BINARY SUBTRACTOR

#### Explain about four bit subtractor with neat diagram.

- By 1's complement method, the bits of subtrahend are complemented and added to the minuend.
   If any carry is generated it is added to the sum output.
- Below Figure demonstrates the subtraction of  $B_4 B_3 B_2 B_1$  from  $A_4 A_3 A_2 A_1$ .
- Each bit of B<sub>4</sub> B<sub>3</sub> B<sub>2</sub> B<sub>1</sub> is first complemented by using INVERTER gates and added to A4 A<sub>3</sub> A<sub>2</sub>
   A<sub>1</sub> by a 4-bit binary adder.
- End round carry is again added using the  $C_{in}$  pin of the IC.



# Fast adder (or) Carry Look Ahead adder

# Design a carry look ahead adder circuit. Fast Adder:

- Every logic gate offers some delay when the signal passes from its input to output, which is called the propagation delay of the logic gate.
- So every combinational circuit takes some time to produce its correct output after the arrival of all the input, which is called total propagation time.
- Total propagation time is equal to the propagation delay of individual gates times the number of gate levels in the circuit.
- For a 4-bit parallel binary adder, carry propagation takes the longest propagation time.
- One method to reduce the propagation delay time is to use faster gates.

#### DE.

#### Page 8

(Nov-2010),(May 2018)

- Another technique is to employ a little more complex combinational circuit, which can reduce the carry propagation delay time.
- The most widely used method employs the principle of look ahead carry generation, which is illustrated below.
- The carry look ahead adder is based on the principle of looking at the lower order bits of the augend and addend to see if a higher order carry is to be generated.
- ✤ It uses two functions carry generate and carry propagate.



◆ Consider the circuit of the full adder shown in Fig. It defines two new binary variables

✤ The output sum and carry can respectively be expressed as

 $P_i = A_i \oplus B_i$ 

 $S_i = P_i \oplus C_i$  and  $C_{i+1} = G_i + P_i C_i$ 

 $\mathbf{G}_i = \mathbf{A}_i \mathbf{B}_i$ 

✤ Gi is called a carry generate, and it generates an output carry if both the inputs A<sub>i</sub> and B<sub>i</sub> are logic 1, regardless of the input carry.

and

P<sub>i</sub> is called the *carry propagate* because it is the term associated with the propagation of the carry from C<sub>i</sub> to C<sub>i</sub>+1.



Fig: Logic diagram

- \* Boolean expressions for the carry output of each stage can be written after substituting  $C_i$  and  $C_{i\!+\!1}$  as
  - $$\begin{split} & C_2 \,=\, G_1 \,+\, P_1 C_1 \\ & C_3 \,=\, G_2 \,+\, P_2 C_2 \,=\, G_2 \,+\, P_2 (G_1 \,+\, P_1 C_1) \,=\, G_2 \,+\, P_2 G_1 \,+\, P_2 P_1 C_1 \\ & C_4 \,=\, G_3 \,+\, P_3 C_3 \,=\, G_3 \,+\, P_3 G_2 \,\,+\, P_3 P_2 G_1 \,+\, P_3 P_2 P_1 C_1 \\ & C_5 \,=\, G_4 \,+\, P_4 C_4 \,=\, G_4 \,+\, P_4 G_3 \,\,+\, P_4 P_3 G_2 \,+\, P_4 P_3 P_2 G_1 \,+\, P_4 P_3 P_2 P_1 C_1. \end{split}$$
- ♦ In fact, all the intermediate carry as well as the final carry  $C_2$ ,  $C_3$ ,  $C_4$ , and  $C_5$  can be implemented by only two levels of gates and available at the same time.
- The final carry  $C_5$  need not have to wait for the intermediate carry to propagate.



#### **BCD** Adder

#### Design to perform BBCD addition.

#### (May -08)(Dec 2017)

- Consider the arithmetic addition of two decimal digits in BCD, together with an input carry from a previous stage.
- Since each input cannot exceed 9, the output sum must not exceed 9 + 9 + 1 = 19 (1 in the sum is input carry from a previous stage).
- If a four-bit binary adder is used, the normal sum output will be of binary form and may exceed 9 or carry may be generated. So the sum output must be converted to BCD form.
- Suppose we apply two BCD digits to a four-bit binary adder. The adder will form the sum in binary and produce a result that ranges from 0 through 19.
- \* These binary numbers are listed in table and are labeled by symbols K, Z8, Z4, Z2, and Z1.
- ✤ K is the carry, and the subscripts under the letter Z represent the weights 8, 4, 2, and 1 that can be assigned to the four bits in the BCD code.





# Derivation of BCD Adder

|   | Bin            | ary S          | um             |    |   | B   | CD Su | m  |                 | Decima |
|---|----------------|----------------|----------------|----|---|-----|-------|----|-----------------|--------|
| K | Z <sub>8</sub> | Z <sub>4</sub> | Z <sub>2</sub> | Z1 | c | \$8 | \$4   | S2 | \$ <sub>1</sub> |        |
| 0 | 0              | 0              | 0              | 0  | 0 | 0   | 0     | 0  | 0               | 0      |
| 0 | 0              | 0              | 0              | 1  | 0 | 0   | 0     | 0  | 1               | 1      |
| 0 | 0              | 0              | 1              | 0  | 0 | 0   | 0     | 1  | 0               | 2      |
| 0 | 0              | 0              | 1              | 1  | 0 | 0   | 0     | 1  | 1               | 3      |
| 0 | 0              | 1              | 0              | 0  | 0 | 0   | 1     | 0  | 0               | 4      |
| 0 | 0              | 1              | 0              | 1  | 0 | 0   | 1     | 0  | 1               | 5      |
| 0 | 0              | 1              | 1              | 0  | 0 | 0   | 1     | 1  | 0               | 6      |
| 0 | 0              | 1              | 1              | 1  | 0 | 0   | 1     | 1  | 1               | 7      |
| 0 | 1              | 0              | 0              | 0  | 0 | 1   | 0     | 0  | 0               | 8      |
| 0 | 1              | 0              | 0              | 1  | 0 | 1   | 0     | 0  | 1               | 9      |
| 0 | 1              | 0              | 1              | 0  | 1 | 0   | 0     | 0  | 0               | 10     |
| 0 | 1              | 0              | 1              | 1  | 1 | 0   | 0     | 0  | 1               | 11     |
| 0 | 1              | 1              | 0              | 0  | 1 | 0   | 0     | 1  | 0               | 12     |
| 0 | 1              | 1              | 0              | 1  | 1 | 0   | 0     | 1  | 1               | 13     |
| 0 | 1              | 1              | 1              | 0  | 1 | 0   | 1     | 0  | 0               | 14     |
| 0 | 1              | 1              | 1              | 1  | 1 | 0   | 1     | 0  | 1               | 15     |
| 1 | 0              | 0              | 0              | 0  | 1 | 0   | 1     | 1  | 0               | 16     |
| 1 | 0              | 0              | 0              | 1  | 1 | 0   | 1     | 1  | 1               | 17     |
| 1 | 0              | 0              | 1              | 0  | 1 | 1   | 0     | 0  | 0               | 18     |
| 1 | 0              | 0              | 1              | 1  | 1 | 1   | 0     | 0  | 1               | 19     |





- ◆ A BCD adder that adds two BCD digits and produces a sum digit in BCD is shown in Fig.
- The two decimal digits, together with the input carry, are first added in the top four-bit adder to produce the binary sum.
- When the output carry is equal to 0, nothing is added to the binary sum. When it is equal to 1, binary 0110 is added to the binary sum through the bottom four-bit adder.
- ✤ The condition for a correction and an output carry can be expressed by the Boolean function

$$C = K + Z8Z4 + Z8Z2$$

- The output carry generated from the bottom adder can be ignored, since it supplies information already available at the output carry terminal.
- A decimal parallel adder that adds n decimal digits needs n BCD adder stages.
- ◆ The output carry from one stage must be connected to the input carry of the next higher order stage.

\*\*\*\*\*

# MULTIPLEXERS AND DEMULTIPLEXERS

# **Multiplexer: (MUX)** *Design a 2:1 and 4:1 multiplexer.*

- A multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line.
- $\clubsuit$  The selection of a particular input line is controlled by a set of selection lines.
- Normally, there are 2<sup>n</sup> input lines and n selection lines whose bit combinations determine which input is selected.

# 2 to 1 MUX:

- ✤ A 2 to 1 line multiplexer is shown in figure below, each 2 input lines A to B is applied to one input of an AND gate.
- Selection lines S are decoded to select a particular AND gate.



- ◆ To derive the gate level implementation of 2:1 MUX we need to have truth table as shown in figure.
- ✤ Boolean expression for output Y,

$$\mathbf{Y} = \mathbf{A}.\mathbf{S'} + \mathbf{B}.\mathbf{S}$$

Truth table

| B | Α | S | Y |
|---|---|---|---|
| 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 |
| 0 | 1 | 0 | 1 |
| 0 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 |
| 1 | 0 | 1 | 1 |
| 1 | 1 | 0 | 1 |
| 1 | 1 | 1 | 1 |



### Logic Diagram:



#### 4 to 1 MUX: (Illustrate the concept of basic 4 –input Multiplexer)

(Dec2018)

- ✤ A 4 to 1 line multiplexer is shown in figure below, each of 4 input lines I<sub>0</sub> to I<sub>3</sub> is applied to one input of an AND gate.
- Selection lines  $S_0$  and  $S_1$  are decoded to select a particular AND gate.
- $\clubsuit$  The truth table for the 4:1 mux is given in the table below.



### **Truth Table:**

| SEL<br>LIN |           | OUTPUT         |
|------------|-----------|----------------|
| <b>S1</b>  | <b>S0</b> | Y              |
| 0          | 0         | I <sub>0</sub> |
| 0          | 1         | I <sub>1</sub> |
| 1          | 0         | I <sub>2</sub> |
| 1          | 1         | I <sub>3</sub> |



- Let us consider that select input combination  $S_1 S_0$  is 01
- The AND gate associated with I<sub>1</sub> will have two of inputs equal to logic 1 and a third input is connected to I<sub>1</sub>.
- $\diamond$  Therefore, output of this AND gate is according to the information provided by channel I<sub>1</sub>.
- Other three AND gates have logic 0 to at least one of their inputs which makes their outputs to logic 0.
- Hence, OR output (Y) is equal to the data provided by the channel  $I_1$ .
- Thus, information from I<sub>1</sub> is available at Y. Normally a multiplexer has an ENABLE input to also control its operation.

\*\*\*\*\*

### Problems :

Example: Implement the Boolean expression using MUX  $F(A,B,C,D) = \sum m(0,1,5,6,8,10,12,15)$ 

(May 2018)

Solution : Implementation table :

|   | $D_0$ | D <sub>1</sub> | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | D <sub>7</sub> |
|---|-------|----------------|-------|-------|-------|-------|-------|----------------|
| ā | 0     | 1              | 2     | 3     | 4     | 5     | 6     | 7              |
| а | 8     | 9              | 10    | 11    | (12)  | 13    | 14    | (15)           |
|   | 1     | а              | а     | 0     | а     | а     | а     | а              |

# Logic Diagram:



\*\*\*\*\*\*

Design 8-to-1 line multiplexer is realized by two 4-to-1 line multiplexers.



Design 16-to-1 multiplexer can be realized with five 4-to-1 multiplexers.



\*\*\*\*\*

#### **DEMULTIPLEXERS:**

#### Explain about demultiplexers.

- Demultiplexing is the process that receives information from one channel and distributes the data over several channels.
- ✤ It is the reverse operation of the multiplexer.
- A demultiplexer is the logic circuit that receives information through a single input line and transmits the same information over one of the possible 2<sup>n</sup> output lines.
- The selection of a specific output line is controlled by the bit combinations of the selection lines.
- ✤ Example: 1-to-4 De-multiplexer

| Г | 'n | n | ťł | 1 | ta | b | le |
|---|----|---|----|---|----|---|----|
|   |    |   |    |   | чч | ~ |    |

| S1 | S0 | FO | F1 | F2 | F3 |
|----|----|----|----|----|----|
| 0  | 0  | D  | 0  | 0  | 0  |
| 0  | 1  | 0  | D  | 0  | 0  |
| 1  | 0  | 0  | 0  | D  | 0  |
| 1  | 1  | 0  | 0  | 0  | D  |



# Logic Diagram:

**Truth Table:** 



|   | IN | PUT       |           | OUTPUT |    |    |    |  |  |  |
|---|----|-----------|-----------|--------|----|----|----|--|--|--|
| Е | D  | <b>S0</b> | <b>S1</b> | Y0     | Y1 | Y2 | ¥3 |  |  |  |
| 1 | 1  | 0         | 0         | 1      | 0  | 0  | 0  |  |  |  |
| 1 | 1  | 0         | 1         | 0      | 1  | 0  | 0  |  |  |  |
| 1 | 1  | 1         | 0         | 0      | 0  | 1  | 0  |  |  |  |
| 1 | 1  | 1         | 1         | 0      | 0  | 0  | 1  |  |  |  |

Design and explain the 1 to 8 Demultiplexer. [NOV 2020]

# **\*** Example: *1-to-8 De-multiplexer*



Figure 5.95

# **Truth Table:**

| Sele | ction In | nputs |           | Outputs                                              |           |                             |           |           |           |                             |  |  |
|------|----------|-------|-----------|------------------------------------------------------|-----------|-----------------------------|-----------|-----------|-----------|-----------------------------|--|--|
| A    | В        | С     | $Y_o$     | $egin{array}{c c c c c c c c c c c c c c c c c c c $ |           |                             |           |           |           |                             |  |  |
| 0    | 0        | 0     | $Y_0 = I$ | 0                                                    | 0         | 0                           | 0         | 0         | 0         | 0                           |  |  |
| 0    | 0        | 1     | 0         | $\mathbf{Y}_1 = \mathbf{I}$                          | 0         | 0                           | 0         | 0         | 0         | 0                           |  |  |
| 0    | 1        | 0     | 0         | 0                                                    | $Y_2 = I$ | 0                           | 0         | 0         | 0         | 0                           |  |  |
| 0    | 1        | 1     | 0         | 0                                                    | 0         | $\mathbf{Y}_3 = \mathbf{I}$ | 0         | 0         | 0         | 0                           |  |  |
| 1    | 0        | 0     | 0         | 0                                                    | 0         | 0                           | $Y_4 = I$ | 0         | 0         | 0                           |  |  |
| 1    | 0        | 1     | 0         | 0                                                    | 0         | 0                           | 0         | $Y_5 = I$ | 0         | 0                           |  |  |
| 1    | 1        | 0     | 0         | 0                                                    | 0         | 0                           | 0         | 0         | $Y_6 = I$ | 0                           |  |  |
| 1    | 1        | 1     | 0         | 0                                                    | 0         | 0                           | 0         | 0         | 0         | $\mathbf{Y}_7 = \mathbf{I}$ |  |  |

# Logic diagram:





## **Example:**

# 1. Implement full adder using De-multiplexer.

#### Solution :

#### Step 1 : Truth table

|   | Inputs |     | Out   | puts |
|---|--------|-----|-------|------|
| Α | В      | Cin | Carry | Sum  |
| 0 | 0      | 0   | 0     | 0    |
| 0 | 0      | 1   | 0     | 1    |
| 0 | 1      | 0   | 0     | 1    |
| 0 | 1      | 1   | 1     | 0    |
| 1 | 0      | 0   | 0     | 1    |
| 1 | 0      | 1   | 1     | 0    |
| 1 | 1      | 0   | 1     | 0    |
| 1 | 1      | 1   | 1     | 1    |

 $\mbox{Step 3}$  : When  $D_{\rm in}$  =1, the demultiplexer gives minterms at the output.



2. Implement the following functions using de-multiplexer. f1 (A,B,C) =  $\sum m(1,5,7)$ , f2 (A,B,C) =  $\sum m(3,6,7)$ Solution:



#### COMPARATORS

Design a 2 bit magnitude comparator.

(May 2006)

It is a combinational circuit that compares two numbers and determine their relative magnitude. The output of comparator is usually 3 binary variables indicating:

#### A<B, A=B, A>B

**1-bit comparator:** Let's begin with 1 bit comparator and from the name we can easily make out that this circuit would be used to compare 1 bit binary numbers.

| A | В | A>B | A=B | A <b< th=""></b<> |
|---|---|-----|-----|-------------------|
| 0 | 0 | 0   | 1   | 0                 |
| 1 | 0 | 1   | 0   | 0                 |
| 0 | 1 | 0   | 0   | 1                 |
| 1 | 1 | 0   | 1   | 0                 |

For a 2-bit comparator we have four inputs A1A0 and B1B0 and three output E ( is 1 if two numbers are equal) G (is 1 when A > B) and L (is 1 when A < B) If we use truth table and K-map the result is



**@2**019)

### **Design of 2 – bit Magnitude Comparator.**

The truth table of 2-bit comparator is given in table below

#### Truth table:

|    | Inp            | outs |                |     | Outputs |                   |
|----|----------------|------|----------------|-----|---------|-------------------|
| A3 | A <sub>2</sub> | A1   | A <sub>0</sub> | A>B | A=B     | A <b< th=""></b<> |
| 0  | 0              | 0    | 0              | 0   | 1       | 0                 |
| 0  | 0              | 0    | 1              | 0   | 0       | 1                 |
| 0  | 0              | 1    | 0              | 0   | 0       | 1                 |
| 0  | 0              | 1    | 1              | 0   | 0       | 1                 |
| 0  | 1              | 0    | 0              | 1   | 0       | 0                 |
| 0  | 1              | 0    | 1              | 0   | 1       | 0                 |
| 0  | 1              | 1    | 0              | 0   | 0       | 1                 |
| 0  | 1              | 1    | 1              | 0   | 0       | 1                 |
| 1  | 0              | 0    | 0              | 1   | 0       | 0                 |
| 1  | 0              | 0    | 1              | 1   | 0       | 0                 |
| 1  | 0              | 1    | 0              | 0   | 1       | 0                 |
| 1  | 0              | 1    | 1              | 0   | 0       | 1                 |
| 1  | 1              | 0    | 0              | 1   | 0       | 0                 |
| 1  | 1              | 0    | 1              | 1   | 0       | 0                 |
| 1  | 1              | 1    | 0              | 1   | 0       | 0                 |
| 1  | 1              | 1    | 1              | 0   | 1       | 0                 |

#### K-Map:







 $\begin{array}{l} A = B = A_1'A_0'B_1'B_0' + A_1'A_0B_1'B_0 + \\ A_1A_0B_1B_0 + A_1A_0'B_1B_0' \\ = A_1'B_1' \left(A_0'B_0' + A_0B_0\right) + A_1B_1 \left(A_0B_0 + A_0'B_0'\right) \\ = \left(A_0 \odot B_0\right) \left(A_1 \odot B_1\right) \end{array}$ 



 $A{\leq}B = A_1'A_0'B_0 + A_0'B_1B_0 + A_1'B_1$ 

Logic Diagram:



### 4 bit magnitude comparator:

Design a 4 bit magnitude comparators. (Apr – 2019) [NOV 2020]

Input

$$A = A_3 A_2 A_1 A_0$$
$$B = B_3 B_2 B_1 B_0$$

Function Equation

$$(A = B) = x_3 x_2 x_1 x_0$$
  

$$(A > B) = A_3 B'_3 + x_3 A_2 B'_2 + x_3 x_2 A_1 B'_1 + x_3 x_2 x_1 A_0 B'_0$$
  

$$(A < B) = A'_3 B_3 + x_3 A'_2 B_2 + x_3 x_2 A'_1 B'_1 + x_3 x_2 x_1 A' n_0 B'_0$$



Four-bit magnitude comparator

# DECODERS AND ENCODERS Decoder:

## Explain about decoders with necessary diagrams.

- A decoder is a combinational circuit that converts binary information from *n* input lines to a maximum of  $2^n$  unique output lines.
- Decoders have a wide variety of applications in digital systems such as data demultiplexing, digital display, digital to analog converting, memory addressing, etc.

### ✤ 2 to 4 decoder:



#### 3 to 8 Decoder:

#### Design 3 to 8 line decoder with necessary diagram.

#### (May -10)

- ✤ The 3-to-8 line decoder consists of three input variables and eight output lines.
- ◆ Each of the output lines represents one of the minterms generated from three variables.
- The internal combinational circuit is realized with the help of INVERTER gates and AND gates.
  Truth table:

|   | Inputs |   | Outputs |                |                |       |       |       |                |    |
|---|--------|---|---------|----------------|----------------|-------|-------|-------|----------------|----|
| x | у      | z | Do      | D <sub>1</sub> | D <sub>2</sub> | $D_3$ | $D_4$ | $D_5$ | D <sub>6</sub> | D7 |
| 0 | 0      | 0 | 1       | 0              | 0              | 0     | 0     | 0     | 0              | 0  |
| 0 | 0      | 1 | 0       | 1              | 0              | 0     | 0     | 0     | 0              | 0  |
| 0 | 1      | 0 | 0       | 0              | 1              | 0     | 0     | 0     | 0              | 0  |
| 0 | 1      | 1 | 0       | 0              | 0              | 1     | 0     | 0     | 0              | 0  |
| 1 | 0      | 0 | 0       | 0              | 0              | 0     | 1     | 0     | 0              | 0  |
| 1 | 0      | 1 | 0       | 0              | 0              | 0     | 0     | 1     | 0              | 0  |
| 1 | 1      | 0 | 0       | 0              | 0              | 0     | 0     | 0     | 1              | 0  |
| 1 | 1      | 1 | 0       | 0              | 0              | 0     | 0     | 0     | 0              | 1  |



\*\*\*\*\*\*

Example: *Implement the function*  $F(A,B,C) = \Sigma(1,3,5,6)$ .



## Design for 3 to 8 decoder with 2 to 4 decoder:

✤ Its *enable* inputs can be used to build a three to eight decoder as follows.

• When  $A_2$  is logic 0, a lower decoder is activated and gives output  $D_0$  to  $D_3$  and an upper decoder is activated for  $A_2$  is logic 1, output  $D_4$  to  $D_7$  are available this time.



Since the three to eight decoder provides all the minterms of three variables, the realization of function in terms of the sum of products can be achieved using a decoder and OR gates as follows.

# Example: Implement full adder using decoder.

Sum is given by  $\sum m(1, 2, 4, 7)$  while Carry is given by  $\sum m(3, 5, 6, 7)$  as given by the minterms each of the OR gates are connected to.



\*\*\*\*\*\*

#### Design for 4 to 16 decoder using 3 to 8 decoder:

- A 4-to-16 line decoder has four input variables and sixteen outputs, whereas a 3-to-8 line decoder consists of three input variables and eight outputs.
- ▶ Input variables are designated as W, X, Y, and Z.

- ➢ W input is used as the ENABLE input of the upper 3-to-8 line decoder, which provides D<sub>8</sub> to D<sub>16</sub> outputs depending on other input variables X, Y, and Z.
- W is also used as an ENABLE input at inverted mode to a lower decoder, which provides D<sub>0</sub> to D<sub>7</sub> outputs.



# ENCODERS

#### Explain about encoders.

- An encoder is a digital circuit that performs the inverse operation of a decoder.
- \* An encoder has  $2^n$  (or fewer) input lines and n output lines.

#### 4 to 2 Encoder

Let 4 to 2 Encoder has four inputs Y3, Y2, Y1 & Y0 and two outputs A1 & A0. The block diagram of 4 to 2 Encoder is shown in the following figure.



Logic Diagram:



 $\begin{array}{l} A1 = Y2 + Y3 \\ A0 = Y3 + Y1 \end{array}$ 

- The output lines, as an aggregate, generate the binary code corresponding to the input value.
   interpret octal to Binary Encoder in brief. [NOV 2020]
   Octal to Binary Encoder: 8 TO 3 ENCODER
- The encoder can be implemented with OR gates whose inputs are determined directly from the truth table.
- Output z is equal to 1 when the input octal digit is 1, 3, 5, or 7.
- Output y is 1 for octal digits 2, 3, 6, or 7, and output x is 1 for digits 4, 5, 6, or 7.
- These conditions can be expressed by the following Boolean output functions:

$$z = D_1 + D_3 + D_5 + D_7$$
  

$$y = D_2 + D_3 + D_6 + D_7$$
  

$$x = D_4 + D_5 + D_6 + D_7$$

The encoder can be implemented with three OR gates.

#### **Truth table:**

|    |                |    | Inp            |                | C     | )utput         | s  |   |   |   |
|----|----------------|----|----------------|----------------|-------|----------------|----|---|---|---|
| Do | D <sub>1</sub> | D2 | D <sub>3</sub> | D <sub>4</sub> | $D_5$ | D <sub>6</sub> | D7 | x | y | z |
| 1  | 0              | 0  | 0              | 0              | 0     | 0              | 0  | 0 | 0 | 0 |
| 0  | 1              | 0  | 0              | 0              | 0     | 0              | 0  | 0 | 0 | 1 |
| 0  | 0              | 1  | 0              | 0              | 0     | 0              | 0  | 0 | 1 | 0 |
| 0  | 0              | 0  | 1              | 0              | 0     | 0              | 0  | 0 | 1 | 1 |
| 0  | 0              | 0  | 0              | 1              | 0     | 0              | 0  | 1 | 0 | 0 |
| 0  | 0              | 0  | 0              | 0              | 1     | 0              | 0  | 1 | 0 | 1 |
| 0  | 0              | 0  | 0              | 0              | 0     | 1              | 0  | 1 | 1 | 0 |
| 0  | 0              | 0  | 0              | 0              | 0     | 0              | 1  | 1 | 1 | 1 |

#### Logic Diagram:



\*\*\*\*

### **Priority Encoder:**

# Design a priority encoder with logic diagram.

# (May 2017, May 2019)

Special type of encoder that senses when two or more inputs are activated simultaneously and

then generates a code corresponding to the highest numbered input

# Truth table:

|    | Inp   | uts            | Outputs        |   |   |   |
|----|-------|----------------|----------------|---|---|---|
| Do | $D_1$ | D <sub>2</sub> | D <sub>3</sub> | x | y | v |
| 0  | 0     | 0              | 0              | х | Х | 0 |
| 1  | 0     | 0              | 0              | 0 | 0 | 1 |
| Х  | 1     | 0              | 0              | 0 | 1 | 1 |
| Х  | Х     | 1              | 0              | 1 | 0 | 1 |
| Х  | х     | Х              | 1              | 1 | 1 | 1 |

|                | Inp            | uts            |                | Outputs |   |   |  |  |
|----------------|----------------|----------------|----------------|---------|---|---|--|--|
| D <sub>0</sub> | D <sub>1</sub> | D <sub>2</sub> | D <sub>3</sub> | x       | у | v |  |  |
| 0              | 0              | 0              | 0              | ×       | × | 0 |  |  |
| 1              | 0              | 0              | 0              | 0       | 0 | 1 |  |  |
| 0              | 1              | 0              | 0              | 0       | 1 | 1 |  |  |
| 1              | 1              | 0              | 0              | •       | 1 | 1 |  |  |
| 0              | 0              | 1              | 0              |         |   |   |  |  |
| 0              | 1              | 1              | 0              | 1       | 0 | 1 |  |  |
| 1              | 0              | 1              |                | 1       |   | 1 |  |  |
| 1              | 1              | 1              | 0              |         |   |   |  |  |
| 0              | 0              | 0              | 1              |         |   |   |  |  |
| 0              | 0              | 1              | 1              |         |   |   |  |  |
| 0              | 1              | 0              | 1              |         |   |   |  |  |
| 0              | 1              | 1              | 1              | 1       | 1 | 1 |  |  |
| 1              |                |                | 1              |         |   |   |  |  |
| 1              | 0              | 1              | 1              |         |   |   |  |  |
| 1              | 1              | 0              | 1              |         |   |   |  |  |
| 1              | 1              | 1              | 1              |         |   |   |  |  |

# K-Map:



#### **Logic Equations:**

$$x = D_2 + D_3$$
  

$$y = D_3 + D_1 D'_2$$
  

$$V = D_0 + D_1 + D_2 + D_3$$

# Logic diagram:



# 4 bit-Parallel adder/subtractor: Explain about binary parallel / adder subtractor.

### (Dec 2018)

- The addition and subtraction operations can be combined into one circuit with one common binary adder by including an exclusive-OR gate with each full adder.
- ★ The mode input *M* controls the operation. When M = 0, the circuit is an adder, and when M = 1, the circuit becomes a subtractor.



- ✤ It performs the operations of both addition and subtraction.
- It has two 4bit inputs  $A_3A_2A_1A_0$  and  $B_3B_2B_1B_0$ .
- The mode input M controls the operation when M=0 the circuit is an adder and when M=1 the circuits become subtractor.
- Each exclusive-OR gate receives input M and one of the inputs of B.
- ♦ When M = 0, we have B xor0 = B. The full adders receive the value of B, the input carry is 0, and the circuit performs A plus B. This results in sum S<sub>3</sub>S<sub>2</sub>S<sub>1</sub>S<sub>0</sub>and carry C<sub>4</sub>.
- ♦ When M = 1, we have B xor 1 = B' and  $C_0 = 1$ . The B inputs are all complemented and a 1 is added through the input carry thus producing 2's complement of B.
- ♦ Now the data A<sub>3</sub>A<sub>2</sub>A<sub>1</sub>A<sub>0</sub>will be added with 2's complement of B<sub>3</sub>B<sub>2</sub>B<sub>1</sub>B<sub>0</sub>to produce the sum i.e., A-B if A≥B or the 2's complement of B-A if A<B.</li>

#### Parity Checker / Generator:

A parity bit is an extra bit included with a binary message to make the number of 1's either odd or even. The message, including the parity bit, is transmitted and then checked at the receiving end for errors. An error is detected if the checked parity does not correspond with the one transmitted.

- The circuit that generates the parity bit in the transmitter is called a *parity generator*. The circuit that checks the parity in the receiver is called a *parity checker*.
- In even parity system, the parity bit is '0' if there are even number of 1s in the data and the parity bit is '1' if there are odd number of 1s in the data.
- In odd parity system, the parity bit is '1' if there are even number of 1s in the data and the parity bit is '0' if there are odd number of 1s in the data.

#### **3-bit Even Parity generator:**

## (Dec 2018)

Design an even parity generator, that generates an even parity bit for every input string of 3 bits.

## **Truth Table:**

| Three | -Bit Me | Parity Bit |   |  |
|-------|---------|------------|---|--|
| x     | y z     |            | Р |  |
| 0     | 0       | 0          | 0 |  |
| 0     | 0       | 1          | 1 |  |
| 0     | 1       | 0          | 1 |  |
| 0     | 1       | 1          | 0 |  |
| 1     | 0       | 0          | 1 |  |
| 1     | 0       | 1          | 0 |  |
| 1     | 1       | 0          | 0 |  |
| 1     | 1       | 1          | 1 |  |

 $P = x \oplus y \oplus z$ 

## Logic Diagram:



# 4-bit Even parity checker: Truth Table:

|   |   | Bits |   | Parity Error<br>Check |
|---|---|------|---|-----------------------|
| x | y | z    | Р | с                     |
| 0 | 0 | 0    | 0 | 0                     |
| 0 | 0 | 0    | 1 | 1                     |
| 0 | 0 | 1    | 0 | 1                     |
| 0 | 0 | 1    | 1 | 0                     |
| 0 | 1 | 0    | 0 | 1                     |
| 0 | 1 | 0    | 1 | 0                     |
| 0 | 1 | 1    | 0 | 0                     |
| 0 | 1 | 1    | 1 | 1                     |
| 1 | 0 | 0    | 0 | 1                     |
| 1 | 0 | 0    | 1 | 0                     |
| 1 | 0 | 1    | 0 | 0                     |
| 1 | 0 | 1    | 1 | 1                     |
| 1 | 1 | 0    | 0 | 0                     |
| 1 | 1 | 0    | 1 | 1                     |
| 1 | 1 | 1    | 0 | 1                     |
| 1 | 1 | 1    | 1 | 0                     |

$$C = x \oplus y \oplus z \oplus P$$

# Logic Diagram:



## TWO MARK QUESTIONS-ANSWERS

## 1) Define combinational logic.

## (May 2008), (Dec 2014)

A combinational circuit consists of logic gates whose outputs at any time are determined from only the present combination of inputs. A combinational circuit performs an operation that can be specified logically by a set of Boolean functions.



## 2) What is sequential circuits?

- Sequential circuits contain logic gates as well as memory cells. Their outputs depend on the present inputs and also on the states of memory elements.
- Since the outputs of sequential circuits depend not only on the present inputs but also on past inputs.

## 3) Write the design procedure for combinational circuits?

The procedure involves the following steps:

- 1. The problem is stated.
- 2. Identify the input variables and output functions.
- 3. The input and output variables are assigned letter symbols.
- 4. The truth table is prepared that completely defines the relationship between the input variables and output functions.
- 5. The simplified Boolean expression is obtained by any method of minimization algebraic method, Karnaugh map method, or tabulation method.
- 6. A logic diagram is realized from the simplified expression using logic gates.

## 4) What is Half adder?

## (May 2019)

A half-adder is an arithmetic circuit block that can be used to add two bits and produce two outputs SUM and CARRY.

The Boolean expressions for the SUM and CARRY outputs are given by the equations

| SUM $S = A.\overline{B} + \overline{A}.B$ | Input vo | ıriables | Output variables |   |  |
|-------------------------------------------|----------|----------|------------------|---|--|
| CARRY $C = A.B$                           | Α        | В        | ${}^{S}$         | C |  |
| chart o 2 mb                              | 0        | 0        | 0                | 0 |  |
|                                           | 0        | 1        | 1                | 0 |  |
|                                           | 1        | 0        | 1                | 0 |  |
|                                           | 1        | 1        | 0                | 1 |  |

# 5) Draw the logic diagram of half adder using NAND gate. (May 2006,13) Logic Diagram: Half adder using NAND gate:





## 6) What is Full adder?

[NOV 2020] (Dec 2013)

A Full-adder is an arithmetic circuit block that can be used to add three bits and produce two outputs SUM and CARRY.

The Boolean expressions for the SUM and CARRY outputs are given by the equations

# 7) Draw the Logic diagram of full adder.



# 8) What is Half subtractor?

(May 2005)

A half-subtractor is a combinational circuit that can be used to subtract one binary digit from another to produce a DIFFERENCE output and a BORROW output.

The Boolean expression for difference and barrow is:

$$D = X'Y + XY'$$
$$B = X'Y$$

9) Draw Full adder using Two half adder.



## 10) What is Full subtractor?

A combinational circuit of full-subtractor performs the operation of subtraction of three bits such as the minuend, subtrahend, and borrow generated from the subtraction operation of previous significant digits and produces the outputs difference and borrow.

The Boolean expression for difference and barrow is:

S = X'Y'Z + X'YZ' + XY'Z' + XYZC = X'Z + X'Y + YZ

# 11) Draw Full subtractor using two half subtractor.



## 12) What is Parallel Binary Adder (Ripple Carry Adder)?

A binary adder is a digital circuit that produces the arithmetic sum of two binary numbers. It can be constructed with full adders connected in cascade, with the output carry from each full adder connected to the input carry of the next full adder in the chain.

13) Draw the logic diagram for four bit binary parallel adder.



## 14) What is 1's complement of a number?

The 1's complement of a binary number is formed by changing 1 to 0 and 0 to 1.

## Example:

- 1. The 1's complement of 1011000 is 0100111.
- 2. The 1's complement of 0101101 is 1010010.

## 15) What is 2's complement of a number?

The 2's complement of a binary number is formed by adding 1 with 1's complement of a binary number.

## Example:

- 1) The 2's complement of 1101100 is 0010100
- 2) The 2's complement of 0110111 is 1001001

## 16) How Subtraction of binary numbers perform using 2's complement addition?

- $\checkmark$  The subtraction of unsigned binary number can be done by means of complements.
- $\checkmark$  Subtraction of A-B can be done by taking 2's complement of B and adding it to A.
- $\checkmark$  Check the resulting number. If carry present, the number is positive and remove the carry.
- ✓ If no carry present, the resulting number is negative, take the 2's complement of result and put negative sign.

#### 17) Given the two binary numbers X = 1010100 and Y = 1000011, perform the subtraction

(a) X - Y and (b) Y - X by using 2's complements.

#### Solution:

(a) X = 1010100

2's complement of Y = +0111101

Sum= 10010001

Discard end carry. Answer: X - Y = 0010001

(b)

$$Y = 1000011$$

2's complement of X = +0101100

There is no end carry.

Therefore, the answer is Y - X = -(2's complement of 1101111) = -0010001.

18) Draw the logic diagram of Parallel Binary Subtractor.



#### **19)** Draw the logic diagram of 2's complement adder/subtractor.

(May 2013)

(May 2018)



The mode input *M* controls the operation. When M = 0, the circuit is an adder, and when M = 1, the circuit becomes a subtractor.

DE. Page 38

#### 20) What is Magnitude Comparator?

#### (Dec 2017)

The comparison of two numbers is an operation that determines whether one number is greater than, less than, or equal to the other number.

A magnitude comparator is a combinational circuit that compares two numbers A and B and determines their relative magnitudes.

The outcome of the comparison is specified by three binary variables that indicate whether

A > B, A = B, or A < B.

#### 21) Design a 1-bit Magnitude Comparator.

#### **Truth table:**

| Inputs |   | Outputs |       |       |
|--------|---|---------|-------|-------|
| B      | Α | A > B   | A = B | A < B |
| 0      | 0 | 0       | 1     | 0     |
| 0      | 1 | 1       | 0     | 0     |
| 1      | 0 | 0       | 0     | 1     |
| 1      | 1 | 0       | 1     | 0     |

#### 22) What is Decoder? Define binary decoder. [NOV 2020] (Dec 2014, May 2019)

A decoder is a combinational circuit that converts binary information from n input lines to a maximum of  $2^n$  unique output lines.

#### 23) Give some applications of Decoders.

Decoders have a wide variety of applications in digital systems such as data demultiplexing, digital display, digital to analog converting, memory addressing, etc.

#### 24) Design a 3 to 8 decoder with 2 to 4 decoder.



DE. Page 39

#### 25) What is Encoder?

## (May 2012)

(Dec 2006, May 2011)

An encoder is a digital circuit that performs the inverse operation of a decoder. An encoder has  $2^n$  (or fewer) input lines and n output lines. The output lines, as an aggregate, generate the binary code corresponding to the input value.

#### 26) What is Priority Encoder?

A priority encoder is an encoder circuit that includes the priority function.

Special type of encoder that senses when two or more inputs are activated simultaneously and then generates a code corresponding to the highest numbered input.

#### 27) Define Multiplexer (MUX) (or) Data Selector.

A multiplexer is a combinational circuit that selects binary information from one of many input lines and directs it to a single output line.

The selection of a particular input line is controlled by a set of selection lines. Normally, there are  $2^n$  input lines and n selection lines whose bit combinations determine which input is selected.

#### 28) What is De-multiplexer?

The de-multiplexer performs the inverse function of a multiplexer, that is it receives information on one line and transmits its onto one of  $2^n$  possible output lines. The selection is by *n* input select lines.

#### **29)** Give the applications of Demultiplexer.

i) It finds its application in Data transmission system with error detection.

ii) One simple application is binary to Decimal decoder.

#### 30) Mention the uses of Demultiplexer.

#### (May 2015)

Demultiplexer is used in computers when a same message has to be sent to different receivers. Not only in computers, but any time information from one source can be fed to several places.

## **33**) Give other name for Multiplexer and Demultiplexer.

Multiplexer is otherwise called as Data selector.

Demultiplexer is otherwise called as Data distributor.

## 34) What is the function of the enable input in a Multiplexer?

The function of the enable input in a MUX is to control the operation of the unit.

#### 35) List out the applications of decoder?

#### (Dec 2006)

- a. Decoders are used in counter system.
- b. They are used in analog to digital converter.
- c. Decoder outputs can be used to drive a display system.

#### **36) What are the Application of MUX?**

- 1. They are used as a data selector to select one output of many data inputs.
- 2. They can be used to implement combinational logic circuits
- 3. They are used in time multiplexing systems.
- 4. They are used in frequency multiplexing systems.
- 5. They are used in A/D & D/A Converter.
- 6. They are used in data acquisition system.

#### **37**) List out the applications of comparators?

- a. Comparators are used as a part of the address decoding circuitry in computers to select a specific input/output device for the storage of data.
- b. They are used to actuate circuitry to drive the physical variable towards the reference value.
- c. They are used in control applications.

## 38) What is carry look-ahead addition?

The speed with which an addition is performed limited by the time required for the carries to propagate or ripple through all of the stage of the adder. One method of speeding up the process is by eliminating the ripple carry delay.

#### 39) What are the Difference between Decoder & Demux.?

| S.No | Decoder                                  | Demux                                                                                |
|------|------------------------------------------|--------------------------------------------------------------------------------------|
| 1    | Decoder is a many inputs to many outputs | Demux is a single input to many outputs                                              |
| 2    | There are no selection lines.            | The selection of specific output line is controlled by the value of selection lines. |



- The addition and subtraction operations can be combined into one circuit with one common binary adder by including an exclusive-OR gate with each full adder.
- The mode input *M* controls the operation. When M = 0, the circuit is an adder, and when M = 1, the circuit becomes a subtractor.
- Each exclusive-OR gate receives input *M* and one of the inputs of *B*.
  - When M = 0, we have B xor 0 = B. The full adders receive the value of B, the input carry is 0, and the circuit performs A plus B.
  - When M = 1, we have B xor 1 = B' and  $C_0 = 1$ . The B inputs are all complemented and a 1 is added through the input carry.
- The circuit performs the operation A plus the 2's complement of B. (The exclusive-OR with output V is for detecting an overflow.)
- The detection of an overflow after the addition of two binary numbers depends on whether the numbers are considered to be signed or unsigned.
- The binary adder–subtractor circuit with outputs C and V is shown in Fig.
- If the two binary numbers are considered to be unsigned, then the C bit detects a carry after addition or a borrow after subtraction.
- If the numbers are considered to be signed, then the V bit detects an overflow.
  - $\circ$  If V = 0 after an addition or subtraction, then no overflow occurred and the n -bit result is correct.
  - $\circ$  If V = 1, then the result of the operation contains n + 1 bits, but only the rightmost n bits of the number fit in the space available, so an overflow has occurred.

\*\*\*\*\*

1. Design a 5x 32 decoder using 3x8 decoder and summarize how many decoders required (

connect d3 and d4 to 2-to-4 line decoder connect d0, d1, and d2 to all 3-to-8 line decoders.

Now connect output of 2-to-4 line decoder to enable pins of 3-to-8 line decoders such that the fir makes first 3-to-8 line decoders enable.

thats it 32 output of 3-to-8 line decoders are your required output



5-to-32 line decoder

2 marks

(May 2018

1. A binary ripple counter is required to count up to 16,383. How many Flipflops are required? If the frequency is 8.192 MHz, What is the frequency at the output of MSB?

3 Flip flops are required. Average frequency= 3/ 8\* 8.192= 3.072M

(May 2018

2. What is the basic principle used to check or generate the proper parity bit in a given code wo The modulo sum of an even number of 1s is always 0 and the modulo sum of an odd number always 1.

#### **CODE CONVERSION**

Design a binary to gray converter. 2017) Binary to Grayconverter

Gray code is unit distance code. Input code: Binary  $[B_3 \ B_2 \ B_1 \ B_0]$ output code: Gray  $[G_3 \ G_2 \ G_1 \ G_0]$ 

## **Truth Table**

| B3 | B2 | B1 | B0 | G3 | G2 | G1 | G0 |
|----|----|----|----|----|----|----|----|
| 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  |
| 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  |
| 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  |
| 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  |
| 0  | 1  | 0  | 0  | 0  | 1  | 1  | 0  |
| 0  | 1  | 0  | 1  | 0  | 1  | 1  | 1  |
| 0  | 1  | 1  | 0  | 0  | 1  | 0  | 1  |
| 0  | 1  | 1  | 1  | 0  | 1  | 0  | 0  |
| 1  | 0  | 0  | 0  | 1  | 1  | 0  | 0  |
| 1  | 0  | 0  | 1  | 1  | 1  | 0  | 1  |
| 1  | 0  | 1  | 0  | 1  | 1  | 1  | 1  |
| 1  | 0  | 1  | 1  | 1  | 1  | 1  | 0  |
| 1  | 1  | 0  | 0  | 1  | 0  | 1  | 0  |
| 1  | 1  | 0  | 1  | 1  | 0  | 1  | 1  |
| 1  | 1  | 1  | 0  | 1  | 0  | 0  | 1  |
| 1  | 1  | 1  | 1  | 1  | 0  | 0  | 0  |



## K-MAP FORG3:





K-MAP FORG2:



G2=B3'B2+B3B2'=B3 **@**B2

(Nov-2009)(Nov

## K-MAP FORG1:

#### K-MAP FORG0:



, B1B0 00 01 11 10 B3B2 0 00 1 0 1 01 0 1 1 0 1 0 1 0 11 1 0 1 10 0

G0=B1' B0+B1B0'=B1 ⊕B0

Logic diagram:

G1=B1'B2+B1B2'=B1 @B2



#### Gray to Binary converter:

Design a gray to binary converter.(OR) Design a combinational circuit that converts a four bit gray code to a four bit binary number using exclusive – OR gates. (Nov-2009) [NOV – 2019]

Gray code is unit distance code. Input code: Gray  $[G_3 G_2 G_1 G_0]$ output code: Binary [B<sub>3</sub> B<sub>2</sub> B<sub>1</sub> B<sub>0</sub>] g(3) g(2) g(1) g(o)b(3) = g(3)i.e GREY 1 0 0 1  $\underline{\mathbf{b}}(\mathbf{2}) = \mathbf{b}(\mathbf{3}) \oplus \mathbf{g}(\mathbf{3})$ Ð Ð  $\mathbf{b}(\mathbf{1}) = \mathbf{b}(\mathbf{2}) \oplus \mathbf{g}(\mathbf{1})$  $\mathbf{b}(\mathbf{o}) = \mathbf{b}(\mathbf{i}) \oplus \mathbf{g}(\mathbf{o})$ b(3) b(2) **b**(1) **b**(**o**) 1 1 0 0 BINARY

## **Truth Table:**

|    | Gray | code |    |      | Natural-bi | inary code |   |
|----|------|------|----|------|------------|------------|---|
| G3 | G2   | G1   | B2 | B1 B |            |            |   |
|    |      |      |    |      |            |            |   |
| 0  | 0    | 0    | 0  | 0    | 0          | 0          | 0 |
| 0  | 0    | 0    | 1  | 0    | 0          | 0          | 1 |
| 0  | 0    | 1    | 0  | 0    | 0          | 1          | 1 |
| 0  | 0    | 1    | 1  | 0    | 0          | 1          | 0 |
| 0  | 1    | 0    | 0  | 0    | 1          | 1          | 1 |
| 0  | 1    | 0    | 1  | 0    | 1          | 1          | 0 |
| 0  | 1    | 1    | 0  | 0    | 1          | 0          | 0 |
| 0  | 1    | 1    | 1  | 0    | 1          | 0          | 1 |
| 1  | 0    | 0    | 0  | 1    | 1          | 1          | 1 |
| 1  | 0    | 0    | 1  | 1    | 1          | 1          | 0 |
| 1  | 0    | 1    | 0  | 1    | 1          | 0          | 0 |
| 1  | 0    | 1    | 1  | 1    | 1          | 0          | 1 |
| 1  | 1    | 0    | 0  | 1    | 0          | 0          | 0 |
| 1  | 1    | 0    | 1  | 1    | 0          | 0          | 1 |
| 1  | 1    | 1    | 0  | 1    | 0          | 1          | 1 |
| 1  | 1    | 1    | 1  | 1    | 0          | 1          | 0 |

## K-Map:













 $B_2 = G_3'G_2 + G_3G_2'$  $= G_3 \oplus G_2$ 



Logic Diagram:



BCD to Excess -3 converter: Design a combinational circuits to convert binary coded decimal number into an excess-3 code.

Excess-3 code is modified form of BCD code.

(Nov-06,09,10, May-08,10)

Excess -3 code is derived from BCD code by adding 3to each coded number.

## Truth table:

|         |                       | BCD            | code           |                | Excess-3 code  |                |    |                |
|---------|-----------------------|----------------|----------------|----------------|----------------|----------------|----|----------------|
| Decimal | <b>B</b> <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> | E <sub>3</sub> | E <sub>2</sub> | E1 | E <sub>0</sub> |
| 0       | 0                     | 0              | 0              | 0              | 0              | 0              | 1  | 1              |
| 1       | 0                     | 0              | 0              | 1              | 0              | 1              | 0  | 0              |
| 2       | 0                     | 0              | 1              | 0              | 0              | 1              | 0  | 1              |
| 3       | 0                     | 0              | 1              | 1              | 0              | 1              | 1  | 0              |
| 4       | 0                     | 1              | 0              | 0              | 0              | 1              | 1  | 1              |
| 5       | 0                     | 1              | 0              | 1              | 1              | 0              | 0  | 0              |
| 6       | 0                     | 1              | 1              | 0              | 1              | 0              | 0  | 1              |
| 7       | 0                     | 1              | 1              | 1              | 1              | 0              | 1  | 0              |
| 8       | 1                     | 0              | 0              | 0              | 1              | 0              | 1  | 1              |
| 9       | 1                     | 0              | 0              | 1              | 1              | 1              | 0  | 0              |

K-Map:





## Logic Diagram



# Excess -3 to BCD converter:

Design a combinational circuit to convert Excess-3 to BCD code. (May 2007)

## Truth table:

| Destand |                | Excess         | -3 code        |                | BCD code       |                       |                |                |
|---------|----------------|----------------|----------------|----------------|----------------|-----------------------|----------------|----------------|
| Decimal | E <sub>3</sub> | E <sub>2</sub> | E <sub>1</sub> | E <sub>0</sub> | B <sub>3</sub> | <b>B</b> <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> |
| 3       | 0              | 0              | 1              | 1              | 0              | 0                     | 0              | 0              |
| 4       | 0              | 1              | 0              | 0              | 0              | 0                     | 0              | 1              |
| 5       | 0              | 1              | 0              | 1              | 0              | 0                     | 1              | 0              |
| 6       | 0              | 1              | 1              | 0              | 0              | 0                     | 1              | 1              |
| 7       | 0              | 1              | 1              | 1              | 0              | 1                     | 0              | 0              |
| 8       | 1              | 0              | 0              | 0              | 0              | 1                     | 0              | 1              |
| 9       | 1              | 0              | 0              | 1              | 0              | 1                     | 1              | 0              |
| 10      | 1              | 0              | 1              | 0              | 0              | 1                     | 1              | 1              |
| 11      | 1              | 0              | 1              | 1              | 1              | 0                     | 0              | 0              |
| 12      | 1              | 1              | 0              | 0              | 1              | 0                     | 0              | 1              |

## K-map simplification





Page 50

# Logic diagram



# Digital trans-receiver / 8 bit Arithmetic and logic unit



The block diagram of 4 to 16 decoder using 3 to 8 decoders



Design an octal-to-binary priority encoder. Provide an output 'V' to indicate that at least one of the inputs is present. The input with the highest subscript number has the highest priority. What will be the value of the four outputs if inputs D2 and D6 are 1 at the same time? [NOV / DEC 2021]

| Inputs |       |       |       |       |       |       |       | Outputs         |
|--------|-------|-------|-------|-------|-------|-------|-------|-----------------|
| $D_0$  | $D_1$ | $D_2$ | $D_3$ | $D_4$ | $D_5$ | $D_6$ | $D_7$ | xyz V           |
| 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | x x x 0         |
| 1      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0001            |
| х      | 1     | 0     | 0     | 0     | 0     | 0     | 0     | 0011            |
| х      | х     | 1     | 0     | 0     | 0     | 0     | 0     | 0101            |
| х      | х     | х     | 1     | 0     | 0     | 0     | 0     | 0111            |
| х      | х     | х     | х     | 1     | 0     | 0     | õ     | 1001            |
| х      | х     | x     | x     | x     | 1     | 0     | 0     | $1 \ 0 \ 1 \ 1$ |
| x      | х     | х     | х     | х     | х     | 1     | 0     | 1001            |
| х      | х     | х     | х     | х     | х     | x     | 1     | 1111            |

If  $D_2 = 1$ ,  $D_6 = 1$ , all others = 0 Output xyz = 100 and V = 1

Draw the logic diagram for 2 to 4 line decoder using NOR gates. [NOV / DEC 2021]



Assume that the Ex-OR gate has a propagation delay of 10 ns and that the AND or OR gates have a propagation delay of 5 ns. What is the total propagation delay time in the fourbit adder? [NOV / DEC 2021]



 $<sup>10 + 5 + 5 + 10 = 30 \</sup>text{ ns}$ 



## **9'S COMPLEMENTER:**

| Inputs | Outputs |                                                  |
|--------|---------|--------------------------------------------------|
| ABCD   | wxyz    |                                                  |
| 0000   | 1001    |                                                  |
| 0000   | 1001    |                                                  |
| 0001   | 1000    |                                                  |
| 0010   | 0111    |                                                  |
| 0011   | 0110    |                                                  |
| 0100   | 0101    |                                                  |
| 0101   | 0100    |                                                  |
| 0110   | 0011    |                                                  |
| 0111   | 0010    |                                                  |
| 1000   | 0001    |                                                  |
| 1001   | 0000    | $d(A, b, c, d) = \Sigma(10, 11, 12, 13, 14, 15)$ |





## BCD to seven segment decoder

Design a BCD to seven segment code converter.

(May-06,10, Nov- 09)



Truth table:

|       |   | BCD | code |   | 7-Segment code |   |   |   |   |   |   |
|-------|---|-----|------|---|----------------|---|---|---|---|---|---|
| Digit | Α | В   | С    | D | a              | ь | с | d | e | f | g |
| 0     | 0 | 0   | 0    | 0 | 1              | 1 | 1 | 1 | 1 | 1 | 0 |
| 1     | 0 | 0   | 0    | 1 | 0              | 1 | 1 | 0 | 0 | 0 | 0 |
| 2     | 0 | 0   | 1    | 0 | 1              | 1 | 0 | 1 | 1 | 0 | 1 |
| 3     | 0 | 0   | 1    | 1 | 1              | 1 | 1 | 1 | 0 | 0 | 1 |
| 4     | 0 | 1   | 0    | 0 | 0              | 1 | 1 | 0 | 0 | 1 | 1 |
| 5     | 0 | 1   | 0    | 1 | 1              | 0 | 1 | 1 | 0 | 1 | 1 |
| 6     | 0 | 1   | 1    | 0 | 1              | 0 | 1 | 1 | 1 | 1 | 1 |
| 7     | 0 | 1   | 1    | 1 | 1              | 1 | 1 | 0 | 0 | 0 | 0 |
| 8     | 1 | 0   | 0    | 0 | 1              | 1 | 1 | 1 | 1 | 1 | 1 |
| 9     | 1 | 0   | 0    | 1 | 1              | 1 | 1 | 1 | 0 | 1 | 1 |









10

1

1

х

X

- The specification above requires that the output be zeroes (none of the segments are lighted up) when the input is not a BCD digit.
- In practical implementations, this may defer to allow representation of hexadecimal digits using the seven segments.

\*\*\*\*\*

#### UNIT III

## SYNCHRONOUS SEQUENTIAL CIRCUITS

Flip flops – SR, JK, T, D, Master/Slave FF – operation and excitation tables, Triggering of FF, Analysis and design of clocked sequential circuits – Design - Moore/Mealy models, state minimization, state assignment, circuit implementation – Design of Counters- Ripple Counters, Ring Counters, Shift registers, Universal Shift Register.

#### SEQUENTIAL CIRCUITS

#### Sequential circuits:

- Sequential circuits employ storage elements in addition to logic gates. Their outputs depend upon the function of the inputs and the state of the storage elements.
- Because the state of the storage elements is a function of previous inputs, the outputs of a sequential circuit depend not only on present values of inputs, but also on past inputs, and the circuit behavior must be specified by a time sequence of inputs and internal states.



## Types of sequential circuits:

There are two main types of sequential circuits, and their classification is a function of the timing of their signals.

## 1. Synchronous sequential circuit:

It is a system whose behavior can be defined from the knowledge of its signals at discrete instants of time.

## 2. Asynchronous sequential circuits:

The behavior of an asynchronous sequential circuit depends upon the input signals at any instant of time and the order in which the inputs change. The storage elements commonly used in asynchronous sequential circuits are time-delay devices.

## LATCHES AND FLIP FLOPS

## Flip-Flop:

- The storage elements (memory) used in clocked sequential circuits are called flipflops. A flip-flop is a binary storage device capable of storing one bit of information.
- ➤ In a stable state, the output of a flip-flop is either 0 or 1.
- A sequential circuit may use many flip-flops to store as many bits as necessary. The block diagram of a synchronous clocked sequential circuit is shown in Fig.
- A storage element in a digital circuit can maintain a binary state indefinitely (as long as power is delivered to the circuit), until directed by an input signal to switch states.
- The major differences among various types of storage elements are in the number of inputs they possess and in the manner in which the inputs affect the binary state.

#### Latch:

The storage elements that operate with signal levels (rather than signal transitions) are referred to as latches; those controlled by a clock transition are flip-flops. Latches are said to be level sensitive devices; flip-flops are edge-sensitive devices.



#### **Triggering of Flip Flops**

#### Explain about triggering of flip flops in detail.

The state of a latch or flip-flop is switched by a change in the control input. This momentary change is called a *trigger*, and the transition it causes is said to trigger the flip-flop.



## Level Triggering:

- > SR, D, JK and T latches are having enable input.
- Latches are controlled by enable signal, and they are level triggered, either positive level triggered or negative level triggered as shown in figure (a).
- The output is free to change according to the input values, when active level is maintained at the enable input.

## **Edge Triggering:**

- $\blacktriangleright$  A clock pulse goes through two transitions: from 0 to 1 and the return from 1 to 0.
- As shown in above Fig (b) and (c)., the positive transition is defined as the positive edge and the negative transition as the negative edge.

\*\*\*\*\*

## FLIP FLOP CONVERSIONS

> The purpose is to convert a given type A FF to a desired type B FF using some conversion logic.



> To use the excitation table, which shows the necessary triggering signal (S,R, J,K, D and T) for a

:

$$Q_t \to Q_{t+1}$$

desired flip-flop state transition

## **Excitation table for all flip flops:**

| Qt | Q <sub>t+1</sub> | S | R | D | J | K | Т |
|----|------------------|---|---|---|---|---|---|
| 0  | 0                | 0 | Х | 0 | 0 | Х | 0 |
| 0  | 1                | 1 | 0 | 1 | 1 | Х | 1 |
| 1  | 0                | 0 | 1 | 0 | X | 1 | 1 |
| 1  | 1                | Х | 0 | 1 | X | 0 | 0 |

## 1. Design of JK Flip-flop using SR Flip-Flop.

S-R Flip Flop to J-K Flip Flop









 $\mathbf{R} = \mathbf{K} \mathbf{O} \mathbf{n}$ 

## 2. Design of SR Flip-flop using JK Flip-Flop.

J-K Flip Flop to S-R Flip Flop

Conversion Table

Logic Diagram



#### 3. Design of D Flip-flop using SR Flip-Flop.

Show how S-R flip flop is converted into D-flip flop. [NOV 2020]

S-R Flip Flop to D Flip Flop



#### 4. Design of SR Flip-flop using D Flip-Flop.

D Flip Flop to S-R Flip Flop

| Conversion Table |   |                    |      |           |  |  |  |  |  |
|------------------|---|--------------------|------|-----------|--|--|--|--|--|
| S-R Inputs       |   | Outputs<br>Qp Qp+1 |      | D Input   |  |  |  |  |  |
| 0                | 0 | 0                  | 0    | 0         |  |  |  |  |  |
| 0                | 0 | 1                  | 1    | 1         |  |  |  |  |  |
| 0                | 1 | 0                  | 0    | 0         |  |  |  |  |  |
| 0                | 1 | 1                  | 0    | 0         |  |  |  |  |  |
| 1                | 0 | 0                  | 1    | 1         |  |  |  |  |  |
| 1                | 0 | 1                  | 1    | 1         |  |  |  |  |  |
| 1                | 1 | Inv                | alid | Dont care |  |  |  |  |  |
| 1                | 1 | Inv                | alid | Dont care |  |  |  |  |  |



1

RQp

0

s

0

1  K-map

0

10

0

х





#### D = S+RQn

## 5. Design of T Flip-flop using JK Flip-Flop.

#### J-K Flip Flop to T Flip Flop

Qp

0

1

х

İΧ

K=T

0









Logic Diagram



#### 6. Design of D Flip-flop using JK Flip-Flop.



#### J-K Flip Flop to D Flip Flop

## 7. Design of JK Flip-flop using D Flip-Flop.

#### Dec 2009,11



#### 

#### MEALY AND MOORE MODELS

#### Write short notes on Mealy and Moore models in sequential circuits.

In synchronous sequential circuit the outputs depend upon the order in which its input variables change and can be affected at discrete instances of time.

#### General Models:

- > There are two models in sequential circuits. They are:
  - 1. Mealy model
  - 2. Moore model

Page 6

## Moore machine:

> In the Moore model, the outputs are a function of present state only.



## Mealy machine:

> In the Mealy model, the outputs are a function of present state and external inputs.



#### \*\*\*\*\*

## COUNTERS

#### Counter:

- A counter is a register (group of Flip-Flop) capable of counting the number of clock pulse arriving at its clock input.
- > A counter that follows the binary number sequence is called a binary counter.
- Counter are classified into two types,
  - 1. Asynchronous (Ripple) counters.
  - 2. Synchronous counters.
- > In ripple counter, a flip- flop output transition serves as clock to next flip-flop.
  - With an asynchronous circuit, all the bits in the count do not all change at the same time.
- > In a synchronous counter, all flip-flops receive common clock.
  - With a synchronous circuit, all the bits in the count change synchronously with the assertion of the clock
- > A counter may count up or count down or count up and down depending on the input control.

## Uses of Counters:

The most typical uses of counters are

- ✓ To count the number of times that a certain event takes place; the occurrence of event to be counted is represented by the input signal to the counter
- $\checkmark$  To control a fixed sequence of actions in a digital system
- $\checkmark$  To generate timing signals
- ✓ To generate clocks of different frequencies

## Modulo 16 ripple /Asynchronous Up Counter/Serial up counter

#### Explain the operation of a 4-bit binary ripple counter.

(May 2014, Dec 2015)

- > The output of up-counter is incremented by one for each clock transition.
- > A 4-bit asynchronous up-counter consists of 4JK Flip-Flops.
- > The external clock signal is connected to the clock input of the first FlipFlop.
- > The clock inputs of the remaining Flip-Flops are triggered by the Q output of the previous stage.
- ➤ We know that in JK Flip-Flop, if J=1, K=1 and clock is triggered the past output will be complemented.

- > Initially, the register is cleared,  $Q_D Q_C Q_B Q_A = 0000$ .
- > During the *first clock pulse*, Flip-Flop A triggers, therefore  $Q_A=1$ ,  $Q_B=Q_C=Q_D=0$ .

$$Q_D Q_C Q_B Q_A = 0001$$

At the *second clock pulse* FLipFlop A triggers, therefore Q<sub>A</sub> changes from 1 to 0, which triggers FlipFlop B, therefore Q<sub>B</sub>=1,Q<sub>A</sub>=Q<sub>C</sub>=Q<sub>D</sub>=0

$$Q_D Q_C Q_B Q_A = 0010$$

- > At the *third clock pulse* FlipFlop A triggers, therefore Q<sub>A</sub> changes from 0 to 1.
  - This never triggers FlipFlop B because 0 to 1 transition gives a positive edge triggering,
  - but here the FlipFlops are triggered only at negative edge( 1 to 0 transition) ,therefore  $Q_A=Q_B=1, Q_C=Q_D=0.$

$$Q_D Q_C Q_B Q_A = 0011$$

- ➤ At the *fourth clock pulse* Flip-Flop A triggers, therefore Q<sub>A</sub> changes from 1 to 0.
  - $\circ~$  This triggers FlipFLop B therefore  $Q_B$  changes from 1 to 0.
  - $\circ$  The change in Q<sub>B</sub> from 1 to 0 triggers C Flip-Flop,
- > Therefore  $Q_C$  changes from 0 to 1. Therefore  $Q_A=Q_B=Q_D=0$ ,  $Q_C=1$ .

$$Q_{D}Q_{C}Q_{B}Q_{A} = 0100$$
High
$$(LK) = (LK) + $

Figure 4-bit Asynchronous Up-counter

Truth table:

| CLK |    | Out | puts |    |
|-----|----|-----|------|----|
|     | QD | Qc  | QB   | QA |
| -   | 0  | 0   | 0    | 0  |
| 1   | 0  | 0   | 0    | 1  |
| 2   | 0  | 0   | 1    | 0  |
| 3   | 0  | 0   | 1    | 1  |
| 4   | 0  | 1   | 0    | 0  |
| 5   | 0  | 1   | 0    | 1  |
| 6   | 0  | 1   | 1    | 0  |
| 7   | 0  | 1   | 1    | 1  |
| 8   | 1  | 0   | 0    | 0  |
| 9   | 1  | 0   | 0    | 1  |
| 10  | 1  | 0   | 1    | 0  |
| 11  | 1  | 0   | 1    | 1  |
| 12  | 1  | 1   | 0    | 0  |
| 13  | 1  | 1   | 0    | 1  |
| 14  | 1  | 1   | 1    | 0  |
| 15  | 1  | 1   | 1    | 1  |

Truth table for 4-bit asynchronous up-counter

*Timing diagram:* 



Figure 4.37 Timing diagram of 4-bit asynchronous up-counter.

\*\*\*\*\*

#### Modulo 16 /4 bit Ripple Down counter/ Asynchronous Down counter/Serial down counter

# Explain about Modulo 16 /4 bit Ripple Down counter.

- ➤ The output of down-counter is decremented by one for each clock transition.
- > A 4-bit asynchronous down-counter consists of 4JK Flip-Flops.
- > The external clock signal is connected to the clock input of the first Flip-Flop.
- > The clock inputs of the remaining Flip-Flops are triggered by the  $\overline{Q}$  output of the previous stage.
- ➤ We know that in JK Flip-Flop, if J=1, K=1 and clock is triggered the past output will be complemented.



- > Initially, the register is cleared,  $Q_D Q_C Q_B Q_A = 0000$ .
- ▶ During the *first clock pulse*, Flip-Flop A triggers, therefore  $Q_A$  changes from 0 to 1 also  $\overline{Q_A}$  changes from 1 to 0. This triggers Flip-Flop B, therefore  $Q_B$  changes from 0 to 1, also  $\overline{Q_B}$  changes from 1 to 0. This triggers Flip-Flop C.
- $\blacktriangleright$  Hence Q<sub>C</sub> changes from 0 to 1 and Q<sub>C</sub> changes from 1 to 0, which further triggers, Flip-Flop D.

$$\frac{Q_D Q_C Q_B Q_A}{Q_D Q_C} = 1111$$

$$\frac{Q_D Q_C}{Q_B} \frac{Q_B}{Q_A} = 0000$$

- During the *second clock pulse* Flip-Flop A triggers, therefore Q<sub>A</sub> changes from 1 to 0 also Q<sub>A</sub> changes from 0 to 1 which never triggers B Flip-Flop.
- > Therefore C and D Flip-Flop are not triggered.

$$Q_D Q_C Q_B Q_A = 1110$$

> The same procedure repeats until the counter decrements upto 0000.

| CLK | ]              | Out            | puts           |                |
|-----|----------------|----------------|----------------|----------------|
|     | Q <sub>D</sub> | Q <sub>C</sub> | Q <sub>B</sub> | Q <sub>A</sub> |
| -   | 0              | 0              | 0              | 0              |
| 1   | 1              | 1              | 1              | 1              |
| 2   | 1              | 1              | 1              | 0              |
| 3   | 1              | 1              | 0              | 1              |
| 4   | 1              | 1              | 0              | 0              |
| 5   | 1              | 0.             | 1              | 1              |
| 6   | 1              | 0.             | 1              | 0              |
| 7   | 1              | 0              | 0              | 1:             |
| 8   | 1              | 0              | 0              | 0              |
| 9   | 0              | 1              | 1              | 1              |
| 10  | 0              | 1              | 1              | 0              |
| 11  | 0              | 1              | 0              | 1              |
| 12  | 0              | 1              | 0              | 0              |
| 13  | 0              | 0              | 1              | 1              |
| 14  | 0              | 0              | 1              | 0              |
| 15  | 0              | 0              | 0              | 1              |
| 16  | 0              | 0              | 0              | 0              |

Table .... Truth table for 4-bit asynchronous down-counter



Figure 4 ) Timing diagram of 4-bit asynchronous down-counter.

#### \*\*\*\*\*\*

#### **Asynchronous Up/Down Counter:**

#### Explain about Asynchronous Up/Down counter.

- The up-down counter has the capability of counting upwards as well as downwards. It is also called multimode counter.
- In asynchronous up-counter, each flip-flop is triggered by the normal output Q of the preceding flip-flop.
- > In asynchronous down counter, each flip-flop is triggered by the complement output  $\overline{Q}$  of the preceding flip-flop.
- > In both the counters, the first flip-flop is triggered by the clock output.



Figure 3-bit asynchronous up/down-counter

- > If  $Up/\overline{Down} = 1$ , the 3-bit asynchronous up/down counter will perform up-counting. It will count from 000 to 111.
  - If Up/Down =1 gates  $G_2$  and  $G_4$  are disabled and gates  $G_1$  and  $G_3$  are enabled. So that the circuit behaves as an up-counter circuit.
- If Up/Down =0, the 3-bit asynchronous up/down counter will perform down-counting. It will count from 111 to 000.
  - If Up/ $\overline{\text{Down}} = 0$  gates  $G_2$  and  $G_4$  are enabled and gates  $G_1$  and  $G_3$  are disabled. So that the circuit behaves as an down-counter circuit.





\*\*\*\*\*\*

#### 4- bit Synchronous up-counter:

*Explain about 4-bit Synchronous up-counter.* Exhite operation syboos M**O ot**er.



```
CLK
```

# Figure Logic diagram of 4-bit Synchronous up-counter

- In JK Flip-Flop, If J=0, K=0 and clock is triggered, the output never changes. If J=1 and K=1 and the clock is triggered, the past output will be complemented.
- > Initially the register is cleared  $Q_D Q_C Q_B Q_A = 0000$ .
- > During the first clock pulse,  $J_A = K_A = 1$ ,  $Q_A$  becomes 1,  $Q_B$ ,  $Q_C$ ,  $Q_D$  remains 0.

$$Q_D Q_C Q_B Q_A = 0001.$$

> During second clock pulse,  $J_A = K_A = 1$ ,  $Q_A = 0$ .

$$\label{eq:JB} \begin{split} J_B &= K_B = 1, \, Q_B = 1, \, Q_C, \, Q_D \mbox{ remains } 0. \\ Q_D Q_C Q_B Q_A &= 0010. \end{split}$$

> During third clock pulse,  $J_A = K_A = 1$ ,  $Q_A = 1$ .

$$J_B = K_B = 0$$
,  $Q_B = 1$ ,  $Q_C$ ,  $Q_D$  remains 0.  
 $Q_D Q_C Q_B Q_A = 0011$ .

> During fourth clock pulse,  $J_A = K_A = 1$ ,  $Q_A = 0$ .

 $J_B = K_B = 1, Q_B = 0$   $J_C = K_C = 1, Q_C = 1, Q_D$  remains 0  $Q_D Q_C Q_B Q_A = 0100.$ 

> The same procedure repeats until the counter counts up to 1111.

|     | ····· <b>f</b> ······ | ~          |   |           |     |      |                                     |
|-----|-----------------------|------------|---|-----------|-----|------|-------------------------------------|
| CLK |                       |            | 0 | ut        | put | s    |                                     |
|     |                       | QD         |   | С         | Q   |      | Q <sub>A</sub>                      |
|     | 0                     |            | 0 |           | 0   | -    | $\frac{\mathbf{u}_{\mathbf{A}}}{0}$ |
|     | 0                     |            | 0 |           | 0   | +    | 1                                   |
| 2   | 0                     |            | 0 | -†        | 1   | +    | 0                                   |
| 3   | 0                     |            | 0 | -†        | 1   | ╋    | 1                                   |
| 4   | 0                     |            | 1 | -†-       | 0   | +    | 0                                   |
| 5   | 0                     | 1          | 1 | 1         | 0   | +    | 1                                   |
| 6   | 0                     | 1          | 1 | $\dagger$ | 1   | ╀    | 0                                   |
| 7   | 0                     |            | 1 | ╈         | 1   | ╀    | 1                                   |
| 8   | 1                     | 1          | 0 | +         | 0   | +-   | $\overline{0}$                      |
| 9   | 1                     | 1          | 0 | ╀         | 0   | ┢    | 1                                   |
| 10  | 1                     | $\uparrow$ | 0 | ┢         | 1   | -    | 0                                   |
| 11  | 1                     | $\uparrow$ | 0 | ϯ         | 1   | ╋──- | 1                                   |
| 12  | 1                     | 1-         | 1 |           | 0   |      | 0                                   |
| 13  | 1                     | T          | 1 | -         | 0   | ļ    | 1                                   |
| 14  | 1                     | -          | 1 |           | 1   | (    | )                                   |
| 15  | 1                     |            | 1 |           | 1   | ]    |                                     |



Truth table for 4-bit synchronous up-counter





#### 4- bit Synchronous down-counter:

Explain about 4-Bit Synchronous down counter.



# Figure 3 Logic diagram of 4-bit synchronous down-counter

In JK Flip-Flop, If J=0, K=0 and clock is triggered, the output never changes. If J=1 and K=1 and the clock is triggered, the past output will be complemented.

Initially the register is cleared  $Q_D Q_C Q_B Q_A = 0000$  $\overline{Q}_D \overline{Q}_C \overline{Q}_B \overline{Q}_A = 1111$ 

During the *first clock pulse*,  $J_A = K_A = 1$ ,  $Q_A = 1$   $J_B = K_B = 1$ ,  $Q_B = 1$   $J_C = K_C = 1$ ,  $Q_C = 1$   $J_D = K_D = 1$ ,  $Q_D = 1$   $Q_D Q_C Q_B Q_A = 1111$  $\overline{Q_D} \overline{Q_C} \overline{Q_B} \overline{Q_A} = 0000$ 

During the *second clock pulse*,  $J_A = K_A = 1$ ,  $Q_A = 0$ 

$$\begin{split} J_{B} &= K_{B} = 0, \, Q_{B} = 1 \\ J_{C} &= K_{C} = 0, \, Q_{C} = 1 \\ J_{D} &= K_{D} = 0, \, Q_{D} = 1 \\ Q_{D} Q_{C} Q_{B} Q_{A} &= 1110 \\ \overline{Q}_{D} \, \overline{Q}_{C} \, \overline{Q}_{B} \, \overline{Q}_{A} &= 0001 \end{split}$$

During the *third clock pulse*,  $J_A = K_A = 1$ ,  $Q_A = 1$ 

$$J_B = K_B = 1, Q_B = 0$$
  
 $J_C = K_C = 0, Q_C = 1$   
 $J_D = K_D = 0, Q_D = 1$   
 $Q_D Q_C Q_B Q_A = 1101$ 

The process repeats until the counter down-counts up to 0000.

| CLK   |   |     | 0 | u          | pu  | ts         |               |     |
|-------|---|-----|---|------------|-----|------------|---------------|-----|
| · · · | Q |     | Q |            | T   | в          | Q             | A   |
| -     | C | )   | 0 |            | (   |            |               |     |
| 1     | 1 |     | 1 |            | 1   |            | 1             |     |
| 2     | 1 |     | 1 |            | 1   | -          | 0             |     |
| 3     | 1 |     | 1 |            | 0   | -          | 1             |     |
| 4     | 1 | -+  | 1 | -          | 0   | -          | $\frac{1}{0}$ |     |
| 5     | 1 | 1   | 0 | 1          | 1   | +          | 1,            | . i |
| 6     | 1 | 1   | 0 | +          | 1   | +          | 0             | -   |
| 7     | 1 | +   | 0 | ╀          | 0   | ╉          | 1             | 4   |
| 8     | 1 | 1-  | 0 | $\uparrow$ | 0   | ╉          | 0             | 1   |
| 9     | 0 | T   | 1 | t          | 1   | +-         | 1             |     |
| 10    | 0 | T   | 1 | t          | 1   | $\uparrow$ | 0             | 1   |
| 11    | 0 | T   | 1 | t          | 0   | 1-         | 1             | 1   |
| 12    | 0 | Τ   | 1 |            | 0   | ţ.         | 0             | 1   |
| 13    | 0 | Γ   | 0 | r-         | 1.  | -          | 1             | 1   |
| 14    | 0 |     | 0 | -          | 1   |            | 0             |     |
| 15    | 0 | 1   | 0 |            | 0 . | -          | 1             |     |
| 16    | 0 | . ( | ) | . (        | )   | (          | )             |     |





#### Modulo 8 Synchronous Up/Down Counter:

#### *Explain about Modulo 8 Synchronous Up/Down Counter.* Explain the operation of synchronous three bit counter. [NOV 2020]



# Figure 3-bit synchronous up/down-counter

In synchronous up-counter the  $Q_A$  output is given to  $J_B$ ,  $K_B$  and  $Q_A$ .  $Q_B$  is given to  $J_C$ ,  $K_C$ . But in synchronous down –counter  $\overline{Q_A}$  output is given to  $J_B$ ,  $K_B$  and  $\overline{Q_A}$ .  $\overline{Q_B}$  is given to  $J_C$ ,  $K_C$ .

A control input Up/Down is used to select the mode of operation.

If  $Up/\overline{Down} = 1$ , the 3-bit asynchronous up/down counter will perform up-counting. It will count from 000 to 111. If Up/ $\overline{Down} = 1$  gates G<sub>2</sub> and G<sub>4</sub> are disabled and gates G<sub>1</sub> and G<sub>3</sub> are enabled. So that the circuit behaves as an up-counter circuit.

If  $Up/\overline{Down} = 0$ , the 3-bit asynchronous up/down counter will perform down-counting. It will count from 111 to 000. If Up/ $\overline{Down} = 0$  gates  $G_2$  and  $G_4$  are enabled and gates  $G_1$  and  $G_3$  are disabled. So that the circuit behaves as an down-counter circuit.





\*\*\*\*\*

# DESIGN OF SYNCHRONOUS COUNTERS

#### Design and analyze of clocked sequential circuit with an example.

The procedure for designing synchronous sequential circuit is given below,

- 1. From the given specification, Draw the state diagram.
- 2. Plot the state table.
- 3. Reduce the number of states if possible.
- 4. Assign binary values to the states and plot the transition table by choosing the type of Flip-Flop.
- 5. Derive the Flip flop input equations and output equations by using K-map.
- 6. Draw the logic diagram.

# State Diagram:

- State diagram is the *graphical representation of the information available in a state table.*
- In state diagram, a state is represented by a circle and the transitions between states are indicated by directed lines connecting the circles.
- > The state diagram for the logic circuit in below figure.



# **State Table:**

- A state table gives the time sequence of inputs, outputs ad flip flops states. The table consists of four sections labeled present state, next state, input and output.
- The present state section shows the states of flip flops A and B at any given time 'n'. The input section gives a value of x for each possible present state.
- > The next state section shows the states of flip flops one clock cycle later, at time n+1.
- > The state table for the circuit is shown. This is derived using state equations.

|   | sent<br>ate | Input |   | ext<br>ate | Output |
|---|-------------|-------|---|------------|--------|
| A | B           | x     | A | B          | y      |
| 0 | 0           | 0     | 0 | 0          | 0      |
| 0 | 0           | 1     | 0 | 1          | 0      |
| 0 | 1           | 0     | 0 | 0          | 1      |
| 0 | 1           | 1     | 1 | 1          | 0      |
| 1 | 0           | 0     | 0 | 0          | 1      |
| 1 | 0           | 1     | 1 | 0          | 0      |
| 1 | 1           | 0     | 0 | 0          | 1      |
| 1 | 1           | 1     | 1 | 0          | 0      |

The above state table can also be expressed in different forms as follows.

| Dro | esent | N          | Next State         |   |     |                     | tput         |  |
|-----|-------|------------|--------------------|---|-----|---------------------|--------------|--|
|     | ate   | <b>x</b> = | $\overline{x} = 0$ |   | = 1 | <b>x</b> = <b>0</b> | <i>x</i> = 1 |  |
| A   | В     | A          | B                  | A | B   | y                   | y            |  |
| 0   | 0     | 0          | 0                  | 0 | 1   | 0                   | 0            |  |
| 0   | 1     | 0          | 0                  | 1 | 1   | 1                   | 0            |  |
| 1   | 0     | 0          | 0                  | 1 | 0   | 1                   | 0            |  |
| 1   | 1     | 0          | 0                  | 1 | 0   | 1                   | 0            |  |

# State Minimization or state reduction:

- State reduction is concerned with the procedures for reducing the number of states in the state table.
- When two states in the state table are equivalent by producing the same next state and same output then one of the states in the state table can be removed without altering the input output relationship.

# State Assignment:

- > In order to design a sequential circuit, it is necessary to assign binary values to the state.
- ▶ For a circuit with 'm' states, the codes must contain 'n' bits, where  $2^n \ge m$ .
- ▶ For an example, with three bits we can assign codes to maximum of 8 states.

# **Flip-Flop Input Equations:**

The part of the circuit that generates the inputs to flip flops is described algebraically by a set of Boolean functions called flip flop input equations.

\*\*\*\*\*

# Design of a Synchronous Decade Counter Using JK Flip- Flop

A synchronous decade counter will count from zero to nine and repeat the sequence.

# State diagram:

The state diagram of this counter is shown in Fig.



# **Excitation table:**

| P              | resen          | t Sta                 | te    | ו              | Next S         | State |                |                |                |                | Out   | tput  |                       |                  |                |
|----------------|----------------|-----------------------|-------|----------------|----------------|-------|----------------|----------------|----------------|----------------|-------|-------|-----------------------|------------------|----------------|
| Q <sub>3</sub> | Q <sub>2</sub> | <b>Q</b> <sub>1</sub> | $Q_0$ | Q <sub>3</sub> | Q <sub>2</sub> | $Q_1$ | $\mathbf{Q}_0$ | J <sub>3</sub> | K <sub>3</sub> | J <sub>2</sub> | $K_2$ | $J_1$ | <b>K</b> <sub>1</sub> | $\mathbf{J}_{0}$ | K <sub>0</sub> |
| 0              | 0              | 0                     | 0     | 0              | 0              | 0     | 1              | 0              | X              | 0              | Χ     | 0     | X                     | 1                | Χ              |
| 0              | 0              | 0                     | 1     | 0              | 0              | 1     | 0              | 0              | X              | 0              | Χ     | 1     | X                     | X                | 1              |
| 0              | 0              | 1                     | 0     | 0              | 0              | 1     | 1              | 0              | X              | 0              | Χ     | X     | 0                     | 1                | Χ              |
| 0              | 0              | 1                     | 1     | 0              | 1              | 0     | 0              | 0              | X              | 1              | Χ     | Χ     | 1                     | X                | 1              |
| 0              | 1              | 0                     | 0     | 0              | 1              | 0     | 1              | 0              | X              | X              | 0     | 0     | X                     | 1                | Χ              |
| 0              | 1              | 0                     | 1     | 0              | 1              | 1     | 0              | 0              | X              | Χ              | 0     | 1     | X                     | Χ                | 1              |
| 0              | 1              | 1                     | 0     | 0              | 1              | 1     | 1              | 0              | X              | X              | 0     | X     | 0                     | 1                | Χ              |
| 0              | 1              | 1                     | 1     | 1              | 0              | 0     | 0              | 1              | X              | X              | 1     | Χ     | 1                     | Χ                | 1              |
| 1              | 0              | 0                     | 0     | 1              | 0              | 0     | 1              | Χ              | 0              | 0              | Χ     | 0     | X                     | 1                | Χ              |
| 1              | 0              | 0                     | 1     | 0              | 0              | 0     | 0              | Χ              | 1              | 0              | Χ     | 0     | X                     | Χ                | 1              |

# K-Map:





Logic Diagram:



\*\*\*\*\*\*\*\*\*\*\*\*

# Design of a Synchronous Modulus-Six Counter Using SR Flip-Flop

**@2**018)

The modulus six counters will count 0, 2, 3, 6, 5, and 1 and repeat the sequence. This modulus six counter requires three SR flip-flops for the design. (May 2019)

# State diagram:



# Truth table:

| [Pres          | ent St | tate  | Ne    | xt St | ate   |       |       | Out                   | put   |       |       |
|----------------|--------|-------|-------|-------|-------|-------|-------|-----------------------|-------|-------|-------|
| Q <sub>2</sub> | Q1     | $Q_0$ | $Q_2$ | Q1    | $Q_0$ | $R_2$ | $S_2$ | <b>R</b> <sub>1</sub> | $S_1$ | $R_0$ | $S_0$ |
| 0              | 0      | 0     | 0     | 1     | 0     | 0     | Х     | 1                     | 0     | 0     | Х     |
| 0              | 1      | 0     | 0     | 1     | 1     | 0     | Х     | Х                     | 0     | 1     | 0     |
| 0              | 1      | 1     | 1     | 1     | 0     | 1     | 0     | Х                     | 0     | 0     | 1     |
| 1              | 1      | 0     | 1     | 0     | 1     | Х     | 0     | 0                     | 1     | 1     | 0     |
| 1              | 0      | 1     | 0     | 0     | 1     | 0     | 1     | 0                     | Х     | Х     | 0     |
| 0              | 0      | 1     | 0     | 0     | 0     | 0     | Х     | 0                     | Х     | 0     | 1     |

#### K-Map:





Logic Diagram:





# SHIFT REGISTERS

# Explain various types of shift registers.

- A register capable of shifting the binary information held in each cell to its neighboring cell in a selected direction is called a shift register.
- > There are four types of shift registers namely:
  - 1. Serial In Serial Out Shift Register,
  - 2. Serial In Parallel Out Shift Register
  - 3. Parallel In Serial Out Shift Register
  - 4. Parallel In Parallel Out Shift Register

With neat logic diagram and timing diagram, explain the working of PISO and SIPO shift registers. [NOV/DEC 2021]

# **1.Serial In Serial Out Shift Register**

> The block diagram of a serial out shift register is as below.



- It accepts data serially .i.e., one bit at a time on a single input line. It produces the stored information on its single output also in serial form.
- > Data may be shifted left using shift left register or shifted right using shift right register.

# Shift Right Register

The circuit diagram using D flip-fops is shown in figure



Fig. : SISO Shift Register using JK Flip-fion

- > As shown in above figure, the clock pulse is applied to all the flip-flops simultaneously.
- > The output of each flip-flop is connected to D input of the flip-flop at its right.
- Each clock pulse shifts the contents of the register one bit position to the right.
- New data is entered into stage A whereas the data presented in stage D are shifted out.
- For example, consider that all stages are reset and a steady logical 1 is applied to the serial input line.
- When the *first clock pulse* is applied, flip-flop A is set and all other flip-flops are reset.
- When the second clock pulse is applied, the '1' on the data input is shifted into flip-flop A and '1' that was in flip flop A is shifted to flip-flop B.
- > This continues till all flip-flop sets.
- > The data in each stage after each clock pulse is shown in table below

| ſ | Shift Pulse | Serial Data Input | Q   | Q <sub>B</sub> | Q <sub>c</sub> | Serial | Output | QD |
|---|-------------|-------------------|-----|----------------|----------------|--------|--------|----|
|   | 0           | 1                 | 0   | 0              | 0              |        | 0      |    |
|   | 1           | . 1               | 1 . | 0              | 0              |        | 0      |    |
|   | 2           | 1                 | 1   | .1             | 0              |        | 0      |    |
|   | 3           | 1                 | 1   | <b>x</b><br>1  | 1              |        | 0      |    |
|   | 4           | T                 | 1   | 1              | 1              |        | 1      |    |

# Shift Left Register

The figure below shows the shift left register using D flip-flops.



- The clock is applied to all the flip-flops simultaneously. The output of each flip-flop is connected to D input of the flip-flop at its left.
- > Each clock pulse shifts the contents of the register one bit position to the left.
- Let us illustrate the entry of the 4-bit binary number 1111 into the register beginning with the right most bit.
- > When the *first clock pulse* is applied, flip flop A is set and all other flip-flops are reset.
- When second clock pulse is applied, '1' on the data input is shifted into flip-flop A and '1' that was in flip flop A is shifted to flip-flop B. This continues fill all flip-flop are set.
- > The data in each stage after each clock pulse is shown in table below.

| Qp | Qc | Q <sub>B</sub> | QA | Serial Input | Clock |
|----|----|----------------|----|--------------|-------|
|    |    |                |    | Data         | Pulse |
| 0  | 0  | 0              | 0  | 1            | 0     |
| 0  | 0  | 0              | 1  | г            | 1     |
| 0  | 0  | ,1             | 1  | 1            | 2     |
| 0  | 1  | 1              | 1  | 1            | 3     |
| 1  | 1  | 1              | 1  | 1            | 4     |

#### 2. Serial in Parallel out shift register:



Data out

A 4 bit serial in parallel out shift register is shown in figure.



Fig. 3.42: Serial in parallel out shift register

- > It consists of one serial input and outputs are taken from all the flip-flops simultaneously.
- The output of each flip-flop is connected to D input of the flip-flop at its right. Each clock pulse shifts the contents of the register one bit position to the right.
- For example, consider that all stages are reset and a steady logical '1' is applied to the serial input line.
- > When the *first clock pulse* is applied flip flop A is set and all other flip-flops are reset.
- When the *second pulse* is applied the '1' on the data input is shifted into flip flop A and '1' that was in flip flop A is shifted into flip-flop B.
- This continues till all flip-flops are set. The data in each stage after each clock pulse is shown in table below.

| Shift | Serial Data | Parallel Outputs |                |                |                |  |  |  |
|-------|-------------|------------------|----------------|----------------|----------------|--|--|--|
| Pulse | Input       | Q <sub>A</sub>   | Q <sub>B</sub> | Q <sub>c</sub> | Q <sub>p</sub> |  |  |  |
| 0     | 1           | 0                | 0              | 0              | 0              |  |  |  |
| 1     | 1           | 1                | 0              | 0              | 0              |  |  |  |
| 2     | 1           | 1                | 1              | 0              | 0              |  |  |  |
| 3     | 1           | 1                | 1              | 1              | 0<br>0         |  |  |  |
| 4     | 1           |                  | 1              | 1              | 1              |  |  |  |

#### 3. Parallel In Serial Out Shift register:

- For register with parallel data inputs, register the bits are entered simultaneously into their respective stages on parallel lines.
- A four bit parallel in serial out shift register is shown in figure. Let A,B,C and D be the four parallel data input lines and SHIFT/LOAD is a control input that allows the four bits of data to be entered in parallel or shift the serially.



- ➤ When SHIFTS/LOAD is low, gates G1 through G3 are enabled, allowing the data at parallel inputs to the D input of its respective flip-flop.
  - When the clock pulse is applied the flip-flops with D=1 will set and those with D=0 will reset, thereby storing all four bits simultaneously.
- When SHIFT/LOAD is high. AND gates G1 through G3 are disabled and gates G4 through G6 are enabled, allowing the data bits to shifts right from one stage to next.
  - $\circ$  The OR gates allow either the normal shifting operation or the parallel data entry operation, depending on which AND gates are enabled by the level on the SHIFT/LOAD input.

# Parallel In Parallel Out Shift Register:

- In parallel in parallel out shift register, data inputs can be shifted either in or out of the register in parallel.
- ➤ A four bit parallel in parallel out shift register is shown in figure. Let A, B, C, D be the four parallel data input lines and Q<sub>A</sub>, Q<sub>B</sub>, Q<sub>C</sub> and Q<sub>D</sub> be four parallel data output lines. The SHIFT/LOAD is the control input that allows the four bits data to enter in parallel or shift the serially.



Fig. : Parallel in parallel out shift register

- When SHIFT/LOAD is low, gates G1 through G3 are enabled, allowing the data at parallel inputs to the D input of its respective flip-flop.
  - When the clock pule is applied, the flip-flops with D = 1 will *set* those with D=0 will *reset* thereby storing all four bits simultaneously.
  - $\circ$  These are immediately available at the outputs Q<sub>A</sub>, Q<sub>B</sub>, Q<sub>C</sub> and Q<sub>D</sub>.
- When SHIFT/LOAD is high, gates G1, through G3 are disabled and gates G4 through G6 are enabled allowing the data bits to shift right from one stage to another.
  - $\circ$  The OR gates allow either the normal shifting operation or the parallel data entry operation, depending on which AND gates are enabled by the level on the SHIFT/LOAD input.

\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

# **Universal Shift Register**

# (May 2019)

# Explain about universal shift register.

- A register that can shift data to right and left and also has parallel load capabilities is called universal shift register.
- ➢ It has the following capabilities.
  - 1. A shift-right control to enable the shift-right operation and the serial input and output lines associated with the shift-right.
  - 2. A shift-left control to enable the shift-left operation and the serial input and output lines associated with the shift-left.
  - 3. A parallel-load control to enable a parallel transfer and the n input lines associated with the parallel transfer.
  - 4. n parallel output lines.
  - 5. A clear control to clear the register to 0.
  - 6. A CLK input for clock pulses to synchronize all operations.
  - 7. A control state that leaves the information in the register unchanged even though clock pulses are continuously applied.



#### Mode of operation:

- > It consists of four D flip-flop and four multiplexers.
- > When  $S_1 S_0 = 00$ , the present value of the register is applied to the D inputs of the flip-flops.
  - Hence this condition forms a path from the output of each flip-flop into the input of the same flip-flop.
  - The next clock pulse transition transfers into each flip-flop the binary value held previously, and no change of state occurs.
- When  $S_I S_0 = 01$ , terminals 1 of each of the multiplexer inputs have a path to the D inputs of each of the flip-flops.
  - This causes a shift-right operation, with the serial input transferred into flip-flop A<sub>4</sub>.
- Similarly, with  $S_1 S_0 = 10$ , a shift-left operation results, with the other serial input going into flip-flop A<sub>1</sub>.
- Finally, when  $S_1 S_0 = 11$ , the binary information on the parallel input lines is transferred into the register simultaneously during the next clock pulse.

| Mode           | Control         |                    |
|----------------|-----------------|--------------------|
| s <sub>1</sub> | \$ <sub>0</sub> | Register Operation |
| 0              | 0               | No change          |
| 0              | 1               | Shift right        |
| 1              | 0               | Shift left         |
| 1              | 1               | Parallel load      |

\*\*\*\*\*

#### SHIFT REGISTER COUNTERS:

#### Explain about Johnson and Ring counter.

(Dec 2019

[May 2018]

Most common shift register counters are Johnson counter and ring counter.

#### Johnson counter:

A 4 bit Johnson counter using D flip-flop is shown in figure. It is also called shift counter or twisted counter.



- > The output of each flip-flop is connected to D input of the next stage. The inverted output of last flip-flop  $\overline{Q_D}$  is connected to the D input of the first flip-flop A.
- > Initially, assume that the counter is reset to 0. i.e.,  $Q_A Q_B Q_C Q_D = 0000$ . The value at  $D_B = D_C = D_D = 0$ , whereas  $D_A = 1$  since  $\overline{Q_D}$ .
- ➤ When the *first clock pulse is* applied, the first flip-flop A is set and the other flip-flops are reset.
  i.e., Q<sub>A</sub> Q<sub>B</sub> Q<sub>C</sub> Q<sub>D</sub> =1000.
- > When the *second clock pulse* is applies, the counter is  $Q_A Q_B Q_C Q_D = 1100$ . This continues and the counter will fill up with 1's from left to right and then it will fill up with 0's again.
- The sequence of states is shown in the table. As observed from the table, a 4-bit shift counter has 8 states. In general, an *n*-flip-flop Johnson counter will result in 2n states.

| Clock Pulse | Q <sub>A</sub> | Q <sub>B</sub> | Q <sub>c</sub> | Q <sub>D</sub> | $\overline{Q_{D}}$ |
|-------------|----------------|----------------|----------------|----------------|--------------------|
| 0           | 0              | 0              | 0              | 0              | 1                  |
| 1           | 1              | 0              | 0              | 0              | 1                  |
| 2           | 1              | 1              | 0              | 0              | 1                  |
| 3           | 1              | 1              | 1 .            | 0              | 1                  |
| 4           | 1              | 1              | 1              | 1              | 0                  |
| 5           | 0              | 1              | 1              | 1              | 0                  |
| 6           | 0              | 0              | 1              | 1              | 0                  |
| 7           | 0              | 0              | 0              | 1              | 0                  |
| 0           | 0              | 0              | 0              | 0              | 1                  |



# **Ring Counter:**

A 4- bit ring counter using D Flip-Flop is shown in figure.



- As shown in figure, the true output of flip-flop D. i.e., Q<sub>D</sub> is connected back to serial input of flipflop A.
- > Initially, 1 preset into the first flip-flop and the rest of the flip-flops are cleared i.e.,  $Q_A Q_B Q_C Q_D$ =1000.
- When the *first clock pulse is applied*, the second flip-flop is set to 1while the other three flip flops are reset to 0.
- When the second clock pulse is applied, the '1' in the second flip-flop is shifted to the third flipflop and so on.
- > The truth table which describes the operation of the ring counter is shown below.

| <b>Clock</b> Pulse | Q <sub>A</sub> | Q <sub>B</sub> | Q <sub>c</sub> | Q <sub>D</sub> |
|--------------------|----------------|----------------|----------------|----------------|
| 0                  | 1              | 0              | 0              | 0              |
| 1                  | 0              | 1              | 0              | 0              |
| 2                  | 0              | 0              | 1              | 0              |
| 3                  | 0              | 0              | 0              | 1              |
| 0                  | 1              | 0              | 0              | 0              |

As seen a 4-bit ring counter has 4 states. In general, an *n*-bit ring counter has *n* states. Since a single '1' in the register is made to circulate around the register, it is *called a ring counter*. The timing diagram of the ring counter is shown in figure.



1. Eawle bgidlagramad focintable of a 83 lationeented sign ANSy ates.



| Inputs |   | Outputs |    | C  |               |  |
|--------|---|---------|----|----|---------------|--|
| E      | S | R       | 7. |    | Comments      |  |
| 1      | 0 | 0       | Q. | Q. | No change     |  |
| 1      | 0 | 1       | 0  | 1  | Rset          |  |
| 1      | 1 | 0       | 1  | 0  | Set           |  |
| 1      | 1 | 1       | x  | x  | Indeterminate |  |

# **TWO MARKS**

# 1. Difference between Combinational & Sequential Circuits.

| S.no | Combinational Circuits                  | Sequential Circuits                              |  |  |  |
|------|-----------------------------------------|--------------------------------------------------|--|--|--|
| 1    | The output at all times depends only on | The output not only depends on the present       |  |  |  |
|      | the present combination of input        | input but also depends on the past history input |  |  |  |
|      | variables.                              | variables.                                       |  |  |  |
| 2    | Memory unit is not Required             | Memory unit is required to store the past        |  |  |  |
|      |                                         | history of input variable                        |  |  |  |
| 3    | Clock input is not needed.              | Clock input is needed.                           |  |  |  |
| 4    | Faster in Speed                         | Speed is Slower                                  |  |  |  |
| 5    | Easy to design.                         | Difficult to design. Eg: Shift Register,         |  |  |  |
|      | Eg:Mux, Demux, Encoder, Decoder,        | Counters.                                        |  |  |  |
|      | Adders, Subtractors.                    |                                                  |  |  |  |

# 2. What are the classifications of sequential circuits?

The sequential circuits are classified on the basis of timing of their signals in to two types. They are 1) Synchronous sequential circuit.2) Asynchronous sequential circuit.

# 3. Define Latch.

The basic unit for storage is Latch. A Latch maintain its output state either at 1 or 0 until directed by an input signal to change its state.

# 4. Define a flip flop.

A flip-flop is a storage device capable of storing one bit of information. It has two states either 0 or 1. It is also called bistable multivibrator.

# 5. What are the different types of flip-flop?

The various types of flip flops are 1). SR flip-flop 2). D flip-flop 3). JK flip-flop 4). T flip-flop

# 6. What is the main difference between a latch and flip flop?

- $\checkmark$  The output of latch changes immediately when its input changes.
- ✓ The output of a flip-flop changes only when its clock pulse is active and its input changes. Input changes do not affect output if its clock is not activated.

# 7. State few application of Flip-Flop.

- ✓ Used as a memory element.
- ✓ Used as delay elements.
- ✓ Data transfer
- $\checkmark$  Used as a building block in sequential circuits such as counters and registers.

#### 8. What is the operation of D flip-flop?

In D flip-flop during the occurrence of clock pulse if D=1, the output Q is set and if D=0, the output is reset. Set -1, Reset -0.

# 9. What is the operation of JK flip-flop?

When K input is low and J input is high the Q output of flip-flop is set.

When K input is high and J input is low the Q output of flip-flop is reset.

When both the inputs K and J are low the output does not change

When both the inputs K and J are high it is possible to set or reset the flip-flop(ie) the output toggle on the next positive clock edge.

# 10. What is the operation of T flip-flop?

T flip-flop is also known as Toggle flip-flop. 1). When T=0 there is no change in the output. 2). When T=1 the output switch to the complement state (ie) the output toggles.

# 11. Define race around condition.

In JK flip-flop output is fed back to the input. Therefore change in the output results change in the input. Due to this in the positive half of the clock pulse if both J and K are high then output toggles continuously. This condition is called 'race around condition'.

# 12. What is triggering? What is the need for trigger in flip-flop?

A flip-flop is made to change its state by application of a clock pulse after giving inputs. This is called triggering. The clock (triggering input) is given to synchronize the change in the output with it.

# 13. What is meant by level and edge-triggering?

- ✓ If flip-flop changes its state when the clock is positive (high) or negative (low) then, that flipflop is said to be *level triggering flip-flop*.
- ✓ If the flip-flop changes its state at the positive edge (rising edge) or negative edge (falling edge) of the clock is sensitive to its inputs only at this transition of the clock then flip-flop is said to be *edge triggered flip-flop*.

# 14. How do you eliminate race around condition in JK flip flop. ?

Using master-slave flip-flop which consists of two flip-flops where one circuit serves as a master and the other as a slave race around condition in JK flip flop is eliminated .

# **15. Define rise time.**

The time required to change the voltage level from 10% to 90% is known as rise time (t<sub>r</sub>).

# 16. Define fall time.

The time required to change the voltage level from 90% to 10% is known as fall time ( $t_f$ ).

#### 17. Define skew and clock skew.

The phase shift between the rectangular clock waveforms is referred to as skew and the time delay between the two clock pulses is called clock skew.

#### **18. Define setup time.**

The setup time is the minimum time required to maintain a constant voltage levels at the excitation inputs of the flip-flop device prior to the triggering edge of the clock pulse in order for the levels to be reliably clocked into the flip flop.

# 19. Define hold time.

The hold time is the minimum time for which the voltage levels at the excitation inputs must remain constant after the triggering edge of the clock pulse in order for the levels to be reliably clocked into the flip flop.

#### 20. Define propagation delay.

A propagation delay is the time required to change the output after the application of the input

# 21. Explain the flip-flop excitation tables for RS FF.

In RS flip-flop there are four possible transitions from the present state to the Next state. They are

- 1).  $0 \rightarrow 0$  transition: This can happen either when R=S=0 or when R=1 and S=0.
- 2).  $0 \rightarrow 1$  transition: This can happen only when S=1 and R=0.
- 3).  $1 \rightarrow 0$  transition: This can happen only when S=0 and R=1.
- 4).  $1 \rightarrow 1$  transition: This can happen either when S=1 and R=0 or S=0 and R=0.

# 22. Give some applications of clocked RS Flip-flop.

Clocked RS flip flops are used in Calculators & Computers.

It is widely used in modern electronic products.

# 23. What is the drawback of SR Flipflop? How is this minimized?

In SR flipflop when both S and R inputs are one it will generate a Undetermined state. This is Minimized by providing feedback path or by using JK flip flop.

# 24. How many flip flops are required to build a Binary counter that counts from 0 to 1023?

 $2^{10}$ = 1024 hence 10 flipflops are required.

# 25. What is mealy and Moore circuit? Or what are the models used to represent clocked sequential circuits? (Dec 2019

- ✓ *Mealy circuit* is a network where the output is a function of both present state and input.
- ✓ *Moore circuit is* a network where the output is function of only present state

#### 26. What is counter?

A counter is a register (group of Flip-Flop) capable of counting the number of clock pulse arriving at its clock input.

27. What is binary counter?

A counter that follows the binary number sequence is called a binary counter.

#### 28. State the applications of counters.

- 1. Used as a memory Element.
- 2. Used as a Delay Element.
- 3. Used as a basic building block in sequential circuits such as counters and registers.
- 4. Used for Data Transfer, Frequency Division & Counting.

#### **29.** List the types of counters.

Counter are classified into two types,

- ✓ Asynchronous (Ripple) counters.
- ✓ Synchronous counters.

#### (Dec 2017) (May 2018)

#### 30. Give the comparison between synchronous & Asynchronous counters. (Nov/Dec 2009)

| S.No | Asynchronous counters                                      | Synchronous counters                                  |  |  |  |
|------|------------------------------------------------------------|-------------------------------------------------------|--|--|--|
| 1.   | In this type of counter flip-flops are connected in        | In this type there is no connection between           |  |  |  |
|      | such a way that output of 1 <sup>st</sup> flip-flop drives | output of first flip-flop and clock input of the next |  |  |  |
|      | the clock for the next flip - flop.                        | flip – flop                                           |  |  |  |
| 2    | All the flip-flops are not clocked                         | All the flip-flops are clocked simultaneously         |  |  |  |
|      | simultaneously                                             |                                                       |  |  |  |
| 3    | Logic circuit is very simple even for                      | Design involves complex logic circuit as              |  |  |  |
|      | more number of states                                      | number of states increases                            |  |  |  |
| 4    | Counters speed is low.                                     | Counters speed is high.                               |  |  |  |

#### 31. State the Steps or Design procedure for Synchronous Counter.

Preparation of 1). State Diagram

- 2). State Table
- 3). State Assignment
- 4). Excitation Table (Consider which Memory Unit Using)
- 5). K-Map
- 6). Circuit Diagram

#### 32. What is modulo-N counter?

A modulo-n counter will count n states. For example a mod-6 counter will count the sequence 000,001,010,011,100,101 and then recycles to 000. Mod -6 counter skips 110 and 111 states and it goes through only six different states.

#### **33. Define state diagram.**

State diagram is the graphical representation of the information available in a state table. In state diagram, a state is represented by a circle and the transitions between states are indicated by directed lines connecting the circles.

#### 34. What is the use of state diagram?

- i) Behavior of a state machine can be analyzed rapidly.
- ii) It can be used to design a machine from a set of specification.

#### 35. What is state table?

A stable table is a table that represents relationship between inputs, outputs and flip-flop states, is called state table. Generally it consists of four section present state, next state, input and output.

#### **36. What is a state equation?**

A state equation also called, as an application equation is an algebraic expression that specifies the condition for a flip-flop state transition. The left side of the equation denotes the next state of the flip-flop and the right side, a Boolean function specifies the present state.

#### **37. Define sequential circuit.**

Sequential circuits are circuits in which the output variables dependent not only on the present input variables but they also depend up on the past output of these input variables.

#### 38. What do you mean by present state?

The information stored in the memory elements at any given time defines the present state of the sequential circuit.

#### 39. What do you mean by next state?

The present state and the external inputs determine the outputs and the next state of the sequential circuit.

#### 40. Define synchronous sequential circuit.

Synchronous Sequential circuits are circuits in which the signals can affect the memory elements only at discrete instant of time.

# 41. What are the steps for the design of asynchronous sequential circuit?

- iii) Construction of primitive flow table
- iv) Reduction of flow table
- v) State assignment is made
- vi) Realization of primitive flow table

# 42. Define registers.

A register is a group of flip-flops. A n-bit register has a group of n flip-flops and is capable of storing any binary information/number containing n-bits.

# 43. Define shift registers. What is shift register ? [NOV 2020] (Dec 2018)

A register capable of shifting its binary information in one or both directions is called as a shift register. It consists of a chain of flip flops in cascade, with the output of one flip flop connected to the input of the next flip-flop

#### 44. What are the different types of shift registers?[Nov/Dec 2010,April/May 2007]

- ✓ Serial In Serial Out Shift Register
- ✓ Serial In Parallel Out Shift Register
- ✓ Parallel In Serial Out Shift Register
- ✓ Parallel In Parallel Out Shift Register
- ✓ Bidirectional Shift Register

#### 45. State the applications of shift register.

Shift registers are widely used in

- ✓ Time delay circuits
- ✓ As Serial to parallel converter
- ✓ As Parallel to serial converters
- ✓ As Counters

#### 46. Define Shift Register Counter.

A shift register can also be used as a counter. A shift register with the serial output connection back to the serial input is called Shift register counter

#### 47. What is bi-directional shift register and unidirectional shift register?

A register capable of shifting both right and left is called bi-directional shift register. A register capable of shifting only one direction is called unidirectional shift register.

#### 48. What are the two types of shift register counters?[April/May 2007,Nov/Dec 2006,2011,2012]

There are 2 types of shift Register counters are:

Ring counter:

A ring counter is a circular shift register with only one flip flop being set, at any particular time, all others are cleared.

#### Johnson counters:

The Johnson counter is K-bit switch-tail rings counter 2k decoding gates to provide outputs for 2k timing signals.

#### 49. How can a SIPO shift register is converted in to SISO shift register? (Apr/May 2010)

By taking output only on the Q output of last flip flop SIPO shift register is converted in to SISO shift register.

# 50. What is bi-directional shift register and unidirectional shift register?

A register capable of shifting both right and left is called bi-directional shift register. A register capable of shifting only one direction is called unidirectional shift register.

#### 51. What is sequence generator?

The sequential circuit used to repeat a particular sequence repeatedly is called Sequence generator.

# 52. Draw 5-bit Johnson counter.



# 53. Draw the circuit diagram of Ring counter. [NOV/DEC 2021]

**@2**018)

(May 2019)



# 54. Give few applications of shift register.

- ✓ Serial to parallel converter
- ✓ Parallel to serial converter
- $\checkmark$  As a counter
- $\checkmark$  To introduce delay in a digital circuit.

# 55. Hoven floors lave optened in a 10bt rippe oter to realthe

exotafter thotof 1001100111?

Add 1 to the given bary ber ad ote by bis by togged to generate the

enx seque. The no. of bits that has haged is the no. of Freiqued to realmank

oter.

1001100111 - 4 = 1001101000. 4 bis but togged, be 4 Fs reiqed.

\*\*\*\*\*

# FLIP-FLOPS



|         | CLK | S    | R | On | Øn+1 | state                |  |
|---------|-----|------|---|----|------|----------------------|--|
|         | 0   | x    | × | 0  | 0    | at all a             |  |
|         | 0   | X    | × | 1  | ,    | No change            |  |
|         | 1   | 0    | 0 | 0  | 0    |                      |  |
|         | 1   | 0    | 0 | )  | ,    | Nochange             |  |
|         | 1   | 0    | ) | 0  | 0    |                      |  |
|         | 1   | 0    | ) | ,  | 0    | Reset                |  |
|         | •   | 1    | 0 | 0  | 1    |                      |  |
|         | 1   | 1    | 0 | 1  | ,    | set                  |  |
|         | 1   | 1    | 1 | 0  | x    |                      |  |
|         | 1   | 1    | 1 | 1  | *    | Endeter<br>- minale. |  |
| ERATION |     | e og | 2 |    |      |                      |  |

$$cax \underline{i}_{1,2} = \omega han \quad S = 1 \quad \& \quad R = 0$$

$$\Rightarrow \quad S_{1} \longrightarrow have \quad \delta_{n} = 1 \quad A \quad \overline{b}_{n} = 0$$

$$\Rightarrow \quad S_{1} \implies d_{1} x \quad \overline{b}_{n} = 0$$

$$\Rightarrow \quad S_{1} \implies d_{1} x \quad \overline{b}_{n} = 0$$

$$\Rightarrow \quad O[P \quad q] \quad G_{1} \quad becomes \quad logic \quad 0'.$$

$$\Rightarrow \quad O[P \quad q] \quad G_{1} \quad becomes \quad logic \quad 1'$$

$$\Rightarrow \quad Hence \quad The \quad o[P \quad D \quad in \quad \underline{SET} \quad condition .$$

$$case_{i}v_{i} := \quad bohen \quad S = 1 \quad e \quad E = 1$$

$$\Rightarrow \quad S_{1} \longrightarrow have \quad \delta_{n} = 1 \quad , \quad \overline{b}_{n} = 0$$

$$\Rightarrow \quad O[P \quad q] \quad G_{2} \quad x \quad G_{1} \quad becomes \quad logic \quad 0'.$$

$$\Rightarrow \quad O[P \quad q] \quad G_{2} \quad x \quad G_{1} \quad becomes \quad logic \quad 0'.$$

$$\Rightarrow \quad O[P \quad q] \quad G_{2} \quad x \quad G_{1} \quad becomes \quad logic \quad 1'.$$

$$\Rightarrow \quad Hence \quad The \quad \overline{b}_{1} = 0$$

$$\Rightarrow \quad O[P \quad q] \quad G_{2} \quad x \quad G_{1} \quad becomes \quad logic \quad 1'.$$

$$\Rightarrow \quad Hence \quad The \quad T[P \quad coentimentation \quad is \quad and ideol.$$

$$This is ealled indeterminate \quad condition.$$

$$\frac{K - map}{\sigma} \quad for \quad \underline{O}_{n+1} \quad \cdots$$

$$S \quad V \quad O[P \quad \overline{c}_{n+1} \quad \cdots$$

$$S \quad V \quad O[P \quad \overline{c}_{n+1} \quad \cdots$$

$$S \quad V \quad Counton \\ \Rightarrow \quad Hence of U \quad T[P \quad coentimentation is fic \quad eq \quad q' \quad SE - FF \quad U \quad \overline{v}_{n+1} = \quad S + E \quad Q_{n}]$$

$$Per \ Icontions \\\Rightarrow \quad H \quad Quenton \\ \Rightarrow \quad Requiring$$

1

HH

With neat sketches and function table, briefly explain the working of a positive edge triggered D



HS

x

Summarize the operation of JK flip-flop with neat diagram. [NOV 2020]

Flip- Flop: = Explain JR Flip Flep with its truth table and Find the characteristic equation. J.K (Dec 2018 \* Symbol: I Bn On cle cue Bn 00 K , b Negrotine Friggered a, positive 7 rigg ered Logic Diagram: 木



\* Truth Table:

| state         | Bati | On | k | J            | cu |
|---------------|------|----|---|--------------|----|
| No            | 0    | o  | R | x            | 0  |
| change        | ·    | 5  | × | R            | 0  |
| No            | 0    | 0  | Ø | 0            | 1  |
| nlo<br>c home | 1    | ,  | 0 | Ø            | 1  |
| LEVET         | 0    | 0  | ) | 0            | 1  |
|               | Ø    | 1  | ) | 0            | 1  |
| SET           | 1    | 0  | 0 | - <b>f</b> - | 1  |
|               | 1    | 1  | 0 | 1            | 1  |
| Toggles       | 1    | 0  | , | 1            | 1  |
|               | Ø    | 1  | 1 | 1            | 1  |

| J | 1.10 | On1        | state    |
|---|------|------------|----------|
| 0 | 0    | On         | Nochompe |
| 0 | 1    | 0          | REJET    |
| 1 | 0    | N I        | set      |
| 1 | 1    | <b>Ø</b> n | Togges   |

OPERATION:  
CODE J.:. When 
$$T=0 \ e \ E=0$$
  
# Assume  $\Theta_{n=1}$ ;  $\overline{\Theta_{n=0}}$  in all cases.  
# positive edge 7 siggered in all coses.  
# a become i;  $a_2$  becomes i'.  
# olp of  $G_1$  is  $\Theta_{n=1}$ ; olp of  $G_1 \ge \overline{\Theta_{n=0}}$ .  
# Hence the olp does not change if  $T_E$  are low.  
CONE iii when  $T=0 \ e \ E=1$   
# olp of  $G_1$  is  $\Theta_{n=0}$ ; the olp of  $G_2 \ge \overline{\Theta_{n=1}}$ .  
# Hence the olp is in Reset condition.  
CODECIM, when  $T=1 \ E \ K=0$   
# olp of  $G_1$  is  $\Theta_{n=0}$ ; the olp of  $G_2 \ge \overline{\Theta_{n=1}}$ .  
# Hence the olp is in SET condition.  
CODECIM, NOLUM J=1 & K=1  
# olp  $a_1=1$ ;  $a_2=0$   
# thence the olp of  $G_1$  is  $\overline{\Theta_{n=0}}$ ;  
# thence  $f_1$  is  $\overline{\Theta_{n=0}}$ ; the olf of  $G_2$  is  $\overline{\Theta_{n=1}}$ .  
# Hence the olp of  $G_1$  is  $\overline{\Theta_{n=0}}$ ;  
# there olp of  $G_1$  is  $\overline{\Theta_{n=0}}$ .

hg

RACE ABOOND CONDITION ..

of In JR-FF, ofp is fed back to the imput. + Therefore change in the ofp result change in The supert. \* During positive edge truggering, it both J & R are high then output toggles continously. of this condition is called race wound condition.

\* A moided by using Master slowe flip Flop.

K-map of On+1:-



 $B_{n+1} = J \overline{O_n} + \overline{K} O_n$ 

:. Mu characteristic eq. of JK FF is: (8n+1= Jan + k an

A9

\* T- FLIP FLOP:.  
Exp bain Ru op oration of T- FF with its Transh Fable.  
\* Symbol:  

$$\frac{1}{2}$$
  $\frac{1}{2}$   $\frac{1}{2}$ 

OPERATION :-

conc.j, when 
$$\underline{T} = 0$$
  
 $\pi A \text{ showne } \Theta_n = 1 + \Theta_n = 0$   
 $\pi \text{ politive edge } T \text{ siggould is applied:}$   
 $\pi \text{ olp } \alpha_1 = 1 ; \alpha_2 = 1$   
 $\pi \text{ the olp of } \Theta_1 \text{ is } \Theta_n = 1 ;$   
 $\pi \text{ the olp of } \Theta_1 \text{ is } \Theta_n = 0 ;$   
 $\pi \text{ the olp of } \Theta_1 \text{ is } \Theta_n = 0 ;$   
 $\pi \text{ Hence the olp does not chorage if  $T = 0$ .  
Cover,  $M \text{ the olp } \alpha_1 = 1 ; \alpha_2 = 0$ .  
 $\pi \text{ the olp of } \Theta_1 \text{ is } \Theta_n = 0 ;$  the olp of  $\Theta_2 \text{ is } \Theta_n = 1$ .  
 $\pi \text{ the olp of } \Theta_1 \text{ is } \Theta_n = 0 ;$  the olp of  $\Theta_2 \text{ is } \Theta_n = 1$ .  
 $\pi \text{ Hence the output } \Theta_{n+1} \text{ Togg} \text{ for } i \text{ the olp } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } + T \text{ On } 1$   
 $\therefore \text{ One } T \text{ for } T \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ One } T \text{ for } T \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ One } T \text{ for } 1 \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ for } \text{ shore chore form } 1 \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ for } \text{ for } 1 \text{ for } 1 \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ for } \text{ for } 1 \text{ for } 1 \text{ for } 1 \text{ for } 1$   
 $\therefore \text{ for } \text{ for } 1 \text{$$ 

x

Explain the operation of Master Slave flip flop and show how the race around condit SLAVE J-1C - FLIP FLOP Explain the operation of Master Slave J-K Flip Flop. \* The Block diagrouns of a 19 aster slave JK-FF is shown in Fig. 3 15 CLR . CLK' TAK 5 \* It cousists of clocked IR Flip Flop as a master and clocked SK Flop Flop as a starre. \* The clock signal is connected wherearthy to the master the plop. But if is connected through inverter to the \* slave ptip plop. \* millen clock goes high the information present at the JR inputs is transmitted to the output of Master Phip Phop and it is held there, since slame is inactive when clock goes low the stone stip flop \* transfors the output of master the plop. A Since monster is inactive at this instant, it does not steppond to the feedback from Q 2Q.

\* when clock goes low, ou stare will also be REJET making B low and B high. \* fillion J=1 and k=1 and the previous state of the step plop is ser (& of shere =1) the master will be <u>RESET</u> on positive clock. \* When clock goes how, the store will also be RESET. # when the clock goes high again the master will be set and this will set The stame. when clock goes low. The FF is sovial to be TOGGTCE. \* No change in output if both Jik Enparts are low.

write short motes on state Minimization and State assignment.

## State Minimization:

- \* State reduction algorithm is concerned with the procedure for reducing the number of states in the state table.
- \* When two states in the state table are equinalent by producing the share Same next state and same output then one of states in the state table can be removed without altoing the input output relationship. State Assignment:
  - At Sin order to design a sequential citanit. If is necessary to assign bimary malines to the state.
  - \* For a circuit with m' states, the codes must contain n bits, where 2° zm.



Sol ?.

Step F. State Table.

| Prosent<br>Sfate | Neu | spate. | out | pul- |
|------------------|-----|--------|-----|------|
| sture            | X=0 | メニノ    | Z=0 | 2-1  |
| Q.               | a   | с      | 0   | 1    |
| b                | d   | a      | Ø   | 0    |
| c                | e   | Ь      | ,   | 0    |
| d                | a   | 0      | 1   | 0    |

Step 2: Reduce the no. of states if possible. Step 3: Apply state assignment a = 00 b = 01 c = 10 d = 1 1

| e en citation to | uble f | er sr | FG | × \$6 |
|------------------|--------|-------|----|-------|
|                  | Bn     | Ønt,  | 3  | Ŕ     |
|                  | 0      | 0     | 0  | x     |
|                  | 0      | )     | 1  | o     |
|                  | 1      | 0     | 0  | )     |
|                  | 1      | 1     | ×  | 0     |

Step 4: Transition Table.

| star | Taput            | Ne                                     | ut state                                                                                                                                                                                                                                                    | F(                                                                                                                                                                                                                                                            | if Fla                                                                                                                                                                                                                                                                                  | ip ilp                                                                                                                                                                                                                                                                                                                                                                                                    | ,                                                                                                                                                                                                                                                                                                                                                                                     | output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------|------------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | x                | At                                     | B <sup>+</sup>                                                                                                                                                                                                                                              | SA                                                                                                                                                                                                                                                            | RA                                                                                                                                                                                                                                                                                      | SB                                                                                                                                                                                                                                                                                                                                                                                                        | RB                                                                                                                                                                                                                                                                                                                                                                                    | I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | o                | 1                                      | 0                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                             | ×                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                         | X                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Ø    | J                | 1                                      | 0                                                                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                         | x                                                                                                                                                                                                                                                                                                                                                                                     | 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1    | 0                | (                                      | 1                                                                                                                                                                                                                                                           | 1                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                       | x                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                     | O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1    | 1                | Ø                                      | 0                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                             | ĸ                                                                                                                                                                                                                                                                                       | Ø                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                     | Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | 0                | 0                                      | X                                                                                                                                                                                                                                                           | ×                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                         | x                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | 1                | 5                                      | 0                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                         | 0                                                                                                                                                                                                                                                                                                                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1    | 0                | 0                                      | 0                                                                                                                                                                                                                                                           | 0                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                         | 1                                                                                                                                                                                                                                                                                                                                                                                     | ۲                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| l    | 1                | 0                                      | ×                                                                                                                                                                                                                                                           | X                                                                                                                                                                                                                                                             | 0                                                                                                                                                                                                                                                                                       | 0                                                                                                                                                                                                                                                                                                                                                                                                         | (                                                                                                                                                                                                                                                                                                                                                                                     | Ø                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|      | 0<br>1<br>1<br>0 | 0 0<br>0 1<br>1 0<br>1 1<br>0 0<br>0 1 | 0       0       1         0       1       1         1       0       1         1       0       0         0       0       0         0       1       1         1       0       0         0       1       1         1       0       0         1       0       0 | 0     0     1     0       0     1     1     0       1     1     0     1       1     1     0     1       1     1     0     0       X     0     0     1       0     1     1     0       1     0     0     1       0     1     1     0       0     0     0     1 | 0     0     1     0     0       1     0     1     1     0     1       1     0     1     1     0     1       1     1     1     0     0     1       1     1     1     0     0     1       1     1     0     0     0     0       0     0     1     1     0       0     0     0     0     1 | 0     0     1     0     0     X       0     1     0     1     0     1     0       1     0     1     1     0     0     K       1     0     0     0     0     K       0     0     0     0     0     K       0     0     0     0     0     1       1     0     0     0     1       1     0     0     0     1       1     0     0     0     1       1     0     0     0     1       1     0     0     0     1 | B     B     D     B       0     0     1     0     0     X     0       0     1     1     0     1     0     0       1     0     1     1     0     X     0       1     1     0     0     X     0       0     0     0     X     0     0       0     0     0     X     0       0     1     1     0     0     1       1     0     0     0     1     1       1     0     0     0     1     0 | K     K     B     B     B     B     B       0     1     0     1     0     1     0     0       1     0     1     1     0     1     1     0       1     0     1     1     1     1     0     1       1     0     0     1     1     1     0     1       1     0     0     1     1     1     0     1       0     1     1     0     0     1     1     0       1     0     1     1     0     0     1     1       1     0     1     0     0     1     1     0       1     0     1     0     0     1     1     1 |



output ?.



\* Write down the characteristic equation and excitation table for T flip-flop. [NOV/DEC 2021] write the excitation table for flip flop.

| Qt | Q <sub>t+1</sub> | S | R | D | J | Κ | Т |
|----|------------------|---|---|---|---|---|---|
| 0  | 0                | 0 | X | 0 | 0 | Х | 0 |
| 0  | 1                | 1 | 0 | 1 | 1 | Х | 1 |
| 1  | 0                | 0 | 1 | 0 | Х | 1 | 1 |
| 1  | 1                | Х | 0 | 1 | Х | 0 | 0 |

k- anap for BA+1=



: Ont=TOn + TBn

(Dec 2019

**Example 3.3** Design a sequential circuit with 3D Flip-Flops one input x and one output y for the state diagram given below.



Scanned by CamScanner

| 3 Solution | esent sta | te | Input           | Next state |   |   | Output |
|------------|-----------|----|-----------------|------------|---|---|--------|
| A          | В         | С  | x               | A          | В | С | У      |
| 0          | 0         | 0  | 0               | 0          | 1 | 1 | 0      |
| 0          | 0         | 0  | <sup>52</sup> 1 | 1          | 0 | 0 | 1      |
| 0          | 0         | 1  | 0               | 0          | 0 | 1 | 0      |
| 0          | 0         | 1  | 1               | 1          | 0 | 0 | 1      |
| 0          | 1         | 0  | 0               | 0          | 1 | 0 | 0      |
| 0          | 1         | 0  | 1               | 0          | 0 | 0 | 1      |
| 0          | 1         | 1  | 0               | 0          | 0 | 1 | 0      |
| 0          | 1         | 1  | 1               | 0          | 1 | 0 | 1      |
| 1          | 0         | 0  | 0               | 0          | 1 | 0 | 0      |
| 1          | 0         | 0  | 1               | 0          | 1 | 1 | 0      |

## **Transition Table**

|    |           |     |   | Next State |   |   |       |   |       | tput         |
|----|-----------|-----|---|------------|---|---|-------|---|-------|--------------|
| Pr | esent Sta | ate |   | x = 0      |   |   | x = 1 |   | x = 0 | <i>x</i> = 1 |
| A  | B         | С   | Α | В          | С | Α | В     | С | Y     | Y            |
| 0  | 0         | 0   | 0 | 1          | 1 | 1 | 0     | 0 | 0     | 1            |
| 0  | 0         | 1   | 0 | 0          | 1 | 1 | 0     | 0 | 0     | 1            |
| 0  | 1         | 0   | 0 | 1          | 0 | 0 | 0     | 0 | 0     | 1            |
| 0  | 1         | 1   | 0 | 0          | 1 | 0 | 1     | 0 | 0     | 1            |
| 1  | 0         | 0   | 0 | 1          | 0 | 0 | 1     | 1 | 0     | 0            |

## 2. Excitation Table for D Flip-Flop

**Excitation Table for D Flip-Flop** 

| Q               | Q+1 | D |
|-----------------|-----|---|
| 0               | 0   | 0 |
| <mark>-0</mark> | 1   | 1 |
| 1               | 0   | 0 |
| 1               | 1   | 1 |

In the given state diagram five states are there. So three D-Flip-Flops required.

#### Excitation Table for given State Diagram Output **Flip-Flop inputs** Next State Input **Present State** DB D<sub>C</sub> DA С B A B С y х A ÷.,

For D<sub>B</sub>:

### 3. K-Map Simplification

Determine the expressions for  $D_A$ ,  $D_B$ ,  $D_C$  and output y.



$$\begin{array}{c|cccccc} AB & 00 & 01 & 11 & 10 \\ 00 & 1 & 0 & 0 & 0 \\ 01 & 1 & 0 & 1 & 0 \\ 11 & 0 & 1 & 0 \\ 11 & X & X & X \\ 10 & 1 & 1 & X & X \end{array}$$

$$D_A = \overline{A} \overline{B} X$$

$$D_B = A + \overline{C} \overline{X} + BCX$$

### Scanned by CamScanner



Scanned by CamScanner

# UNIT IV ASYNCHRONOUS SEQUENTIAL CIRCUITS

Stable and Unstable states, output specifications, cycles and races, state reduction, race free assignments, Hazards, Essential Hazards, Pulse mode sequential circuits, Design of Hazard free circuits.

#### ASYNCHRONOUS SEQUENTIAL CIRCUITS

#### Write short notes on types of Asynchronous sequential circuits.

- Sequential circuits without clock pulses are called Asynchronous Sequential Circuits. They are classified into 2 types:
  - 1. Fundamental mode circuits
  - 2. Pulse mode circuits

#### Fundamental Mode Circuits:

It assumes that:

- $\checkmark$  The input variables should change only when the circuit is *stable*.
- $\checkmark$  Only one input variable can change at a given time.
- ✓ Inputs and outputs are represented by *levels* (0 or 1).

#### Pulse Mode Circuits:

It assumes that:

- ✓ Inputs and outputs are represented by *pulses*.
- $\checkmark$  The input pulses must be long enough to intimate a state changes.
- $\checkmark$  Pulses are not so wide that the input is still true after a new state is reached.

#### Stable state:

- > If the circuit reaches a steady state condition with *present state*  $y_i = next$  state  $Y_i$  for i=1, 2, 3...K then the circuit is said to be stable state.
- A transition from one stable to another occurs only in response to a change in an input variable.

#### Unstable state:

- ➤ In a circuit, if *present state* y<sub>i</sub> ≠ next state Y<sub>i</sub> for i=1,2,3...K then the circuit is said to be unstable state.
- > The circuit will be in continuous transition till it reached a stable state.

Draw a block diagram of asynchronous sequential circuits.[NOV 2020] Block diagram of Asynchronous Sequential circuits



The communication of two units, with each unit having its own independent clock, must be done with asynchronous circuits.

#### 

ANALYSIS PROCEDURE OF FUNDAMENTAL MODE SEQUENTIAL CIRCUITS (2018)

Explain about analysis procedure of fundamental mode sequential circuits. (Dec2011, May 2019) (2019)

- The analysis of asynchronous sequential circuits consists of obtaining a table or a diagram that described the sequence of internal states and outputs as a function of changes in the input variables.
- > Let us consider the asynchronous sequential circuit is shown in figure.



The analysis of the circuit starts by considering the excitation variables (Y<sub>1</sub> and Y<sub>2</sub>) as outputs and the secondary variables (y<sub>1</sub> and y<sub>2</sub>) as inputs. Step1:

The Boolean expressions are,\

$$Y_1 = xy_1 + x'y_2$$
  
 $Y_2 = x y_1' + x'y_2$ 

*Step 2:* 

 $\blacktriangleright$  The next step is to plot the Y<sub>1</sub> and Y<sub>2</sub> functions in a map



- > Combining the binary values in corresponding squares, the following transition table is obtained.
- The transition table shows the value of  $Y = Y_1Y_2$  inside each square. Those entries where Y = y are circled to indicate a *stable condition*.
- The circuit has four stable total states, y<sub>1</sub>y<sub>2</sub>x=000,011,110, and 101 and four unstable total states-001, 010, 111 and 100.
- > The state table of the circuit is shown below:

| Pre | sent | 1          | Vext | Stat       | e |
|-----|------|------------|------|------------|---|
| St  | ate  | <b>x</b> = | = Q  | <b>x</b> = | 1 |
| 0   | 0    | 0          | 0    | 0          | 1 |
| 0   | 1    | 1          | 1    | 0          | 1 |
| 1   | 0    | 0          | 0    | 1          | 0 |
| 1   | 1    | 1          | T    | 1          | 0 |

> This table provides the same information as the transition table.

#### Step 3:

- Transition table
  - > The transition table is obtained by combining the maps for  $Y_1$  and  $Y_2$ .



- > The transition table is a table which gives the relation between present state, input and next state. If the secondary variables  $y_1 y_2$  is same as excitation variables  $Y_1 Y_2$ , the state is said to be stable.
- > The stable states are indicated by circles. An uncircled entry represents an unstable state.
- In a transition table, usually there will be at least one stable state in each row. Otherwise, all the states in that row will be unstable.

#### Step 4:

#### **Primitive Flow table**

> In a flow table the states are named by letter symbols. Examples of flow tables are as follows:



one input

In order to obtain the circuit described by a flow table, it is necessary to assign to each state a distinct value.

\*\*\*\*\*

Critically examine cycles and races in asynchronous sequential circuits. [NOV 2020] Explain the problems in asynchronous circuits with examples. (Dec 2010,Dec 2012, Dec 2013) Cycles

- A cycle occurs when an asynchronous circuit makes a transition through a *series of unstable state*.
- When a state assignment is made so that it introduces cycles, care must be taken that it terminates with a stable state.
- > Otherwise, the circuit will go from one unstable state to another, until the inputs are changed.
- Examples of cycles are:



Fig: Examples of cycles

#### Race Conditions Discuss about Race

(Dec 2019

- A race condition exists in an asynchronous circuit when two or more binary state variables change value in response to a change in an input variable.
- When unequal delays are encountered, a race condition may cause the state variable to change in an unpredictable manner.
- If the final stable state that the circuit reaches does not depend on the order in which the state variables change, the race is called a noncritical race.
- If the final stable state that the circuit reaches depends on the order in which the state variables change, the race is called a critical race.
- **Examples of noncritical races** are illustrated in the transition tables below:



- > Initial stable state is  $y_1y_2x = 000$  and then input changes from 0 to 1.
- > The state variables  $y_1y_2$  must change from 00 to 11,(race condition).

Possible transitions are

 $\begin{array}{c} 00 \rightarrow 11 \\ 00 \rightarrow 01(y_2 \, \text{faster}) \rightarrow 11 \end{array}$ 

- $00 \rightarrow 10(y_1 \text{ faster}) \rightarrow 11$ 
  - > In all cases final stable state is same, which results in a non-critical race condition.
  - **Examples of critical races** are illustrated in the transition tables below:



- > The initial stable state is  $y_1y_2 = x=000$  and let us consider that the input changes from 0 to 1. Then, the state variables must change from 00 to 11.
- $\blacktriangleright$  If they change simultaneously, the final total state is 111.
- Due to unequal propagation delay, if y<sub>2</sub> changes to 1 before y<sub>1</sub> does, then the circuit goes to total stable state y<sub>1</sub>y<sub>2</sub> x=011 and remains there.

- > If  $y_1$  changes first, then the circuit will be in total stable state is  $y_1y_2 = 101$ .
- Hence the race is critical because the circuit goes to different stable states depending on the order in which the state variables change.

#### \*\*\*\*\*

#### **DESIGN PROCEDURE OF ASYNCHRONOUS SEQUENTIAL CIRCUITS (Dec 2016)**

#### Explain in detail about design procedure of asynchronous sequential circuits. (May 2011, Dec 2017)

There are a number of steps that must be carried out in order to minimize the circuit complexity and to produce a stable circuit without critical races.

The design steps are as follows:

- ✓ Obtain a primitive flow table from the given specification.
- $\checkmark$  Reduce the flow table by merging rows in the primitive flow table.
- ✓ Assign binary states variables to each row of the reduced flow table to obtain the transition table.
- ✓ Assign output values to the dashes associated with the unstable states to obtain the output maps.
- ✓ Simplify the Boolean functions of the excitation and output variables and draw the logic diagram.
- $\checkmark$  The design process will be demonstrated by going through a specific example:

#### Example:

Design a gated latch circuit with two inputs, G (gate) and D (data), and one output Q. The gated latch is a memory element that accepts the value of D when G = 1 and retains this value after G goes to 0. Once G = 0, a change in D does not change the value of the output Q. (May 2016, Dec 2016)

(**O**r)

Design an asynchronous sequential circuit with two inputs D and G with one output Z. Whenever G is 1, input D is transferred to Z. When G is 0, the output does not change for any change in D. Use SR latch for implementation of the circuit.

#### **Primitive Flow Table**

- A primitive flow table is a flow table with only one stable total state in each row. The total state consists of the internal state combined with the input.
- To derive the primitive flow table, first a table with all possible total states in the system is needed:

|       | Inp | uts | Output |                        |
|-------|-----|-----|--------|------------------------|
| State | D   | G   | Q      | Comments               |
| a     | 0   | 1   | 0      | D = Q because $G = 1$  |
| b     | 1   | 1   | 1      | D = Q because $G = 1$  |
| с     | 0   | 0   | 0      | After state a or d     |
| d     | 1   | 0   | 0      | After state c          |
| e     | 1   | 0   | 1      | After state $b$ or $f$ |
| f     | 0   | 0   | 1      | After state e          |

Each row in the above table specifies a total state; the resulting primitive table for the gated latch is shown below:

|        |   |      | Input | s DG          |              |
|--------|---|------|-------|---------------|--------------|
|        |   | 00   | 01    | 11            | 10           |
|        | a | c,-  | @,0   | b ,-          | -,-          |
|        | ь |      | a , - | <u>(</u> ), 1 | e            |
| les    | c | ©, 0 | a ,-  |               | d            |
| States | d | c,-  | -,-   | b ,-          | @.0          |
|        | e | f    | -,-   | b ,-          | <b>(</b> , 1 |
|        | f | Ø, 1 | a ,-  | - , -         | e ,-         |

- First, fill in one square in each row belonging to the stable state in that row.
- > Next recalling that both inputs are not allowed to change at the same time.
- Then enter dash marks in each row that differs in two or more variables from the input variables associated with the stable state.

#### **Reduction of primitive flow table:**

- Two or more rows in the primitive flow table can be merged into one row if there are nonconflicting states and outputs on each of the columns.
- > This can be done by implication table and merger diagram.
- The implication table has all states except the first vertically and all states except the last across bottom horizontally.
- > The tick (  $\checkmark$  ) mark denotes that the pair (rows) is compatible.
- > Two states are compatible, if the states are identical with non-conflicting outputs.
- The cross (x) mark implies non-compatible.



 $\succ$  The compatible pairs are

(a,b), (a,c), (a,d), (b,e), (b,f), (c,d), (e,f)

#### Merger Diagram:

- > The maximum compatible sets can be obtained from merger diagram as shown in figure.
- The merger diagram is a graph in which each state is represented by a dot placed along the circumference of a circle.
- > Lines are drawn between any two corresponding dot that form a compatible pair.
- Based on the geometrical patterns formed by the lines, all the possible compatibilities can be obtained.



- > An isolated dot represents a state that is not compatible with any other state.
- ➤ A line represents a compatible pair.
- ➤ A triangle constitutes a compatible with three states.
- An n-state compatible is represented in the merger diagram by an n-sided polygon with all its diagonal connected.
- ➢ So, the maximal compatibilities are

(a,b) , (a,c,d) , (b,e,f)

#### **Closed covering condition:**

- > In the above, if only (a,c,d) and (b,e,f) are selected, all the six states are incuded.
- > This set satisfies the covering condition.
- > Thus, the rows a, c, d can be merged as one row and b, e, f states can be merged as another row.

| States  | G<br>00        | 01     | 11             | 10    |
|---------|----------------|--------|----------------|-------|
| a, c, d | © <u>,</u> 0   | (a), 0 | b, –           | (), 0 |
| b, e, f | <b>(f</b> ), 1 | a, –   | <b>(b)</b> , 1 | ©, 1  |

Fig. : Reduced flow table

 $\blacktriangleright$  Consider *a*,*c*,*d* =*a* and *b*,*e*,*f* =*b* 



Fig. : Reduced flow table with common symbol

▶ A race free binary assignment is made and transition table and output map is obtained.



#### Logic Diagram using SR Latch:

Excitation table of SR flip-flop is used to find expressions for S and R.

| $Q_n$ | $Q_{1} + 1$ | S | R |
|-------|-------------|---|---|
| 0     | 0           | 0 | X |
| 0     | 1           | 1 | 0 |
| 1     | 0           | 0 | 1 |
| 1     | 1           | x | 0 |





S = DG

| 0 X X 0 X<br>1 0 1 0 0 |   | ,<br>00 | 01 | 11 | 10 |
|------------------------|---|---------|----|----|----|
| 1 0 1 0 0              | - | х       |    | 0  | х  |
|                        | 1 | 0       | 1  | 0  | 0  |

 $R = \overline{D}G$ 



Q

Fig. : Logic diagram using SR latch

#### \*\*\*\*\*\*\*

## RACE -FREE STATE ASSIGNMENT (2019)

M2019)

#### *Explain in detail about race -free state assignment.* May 2012, Dec. 2014, Dec 2015 (2018)

- > To avoid critical races, it is necessary that present state and next state should be given adjacent assignments.
- > If the present state and next state are said to be adjacent, if the binary value differ in only one bit.
- ▶ For an example 010 and 011 are adjacent because they differ only in the third bit.
- > The binary values 010 and 111 are not adjacent because the first and third bit differs.
- Consider the reduced state table is shown below.

| Present State         | Next State A <sup>+</sup> B <sup>+,</sup> Output Z |                           |                           |                           |
|-----------------------|----------------------------------------------------|---------------------------|---------------------------|---------------------------|
|                       | xy=00                                              | xy=01                     | xy=11                     | xy=10                     |
| S <sub>0</sub>        | (S <sub>0</sub> ), 0                               | (S <sub>0</sub> ),0       | <b>S</b> <sub>2</sub> , - | <b>S</b> <sub>1</sub> , - |
| S <sub>1</sub>        | <b>S</b> <sub>0</sub> , -                          | <b>S</b> <sub>2</sub> , - |                           | $(S_1)$ 0                 |
| <b>S</b> <sub>2</sub> | S <sub>0</sub> , -                                 | (S <sub>2</sub> )1        | $(S_2)$ 1                 | S <sub>1</sub> , -        |

> Now if we assign  $S_0 = 00$ ,  $S_1 = 01$  and  $S_2 = 10$ 

| Present State              | Next State A <sup>+</sup> B <sup>+,</sup> Output Z |       |       |       |  |
|----------------------------|----------------------------------------------------|-------|-------|-------|--|
|                            | xy=00                                              | xy=01 | xy=11 | xy=10 |  |
| S <sub>0</sub> (00)        | 00, 0                                              | 00, 0 | 10, - | 01, - |  |
| <b>S</b> <sub>1</sub> (01) | 00, -                                              | 10, - | 01, 0 | 01, 0 |  |
| <b>S</b> <sub>2</sub> (10) | 00, -                                              | 10,1  | 10,1  | 01, - |  |

#### Table: State Assignment without race free

- ▶ Here if the present state is AB=01 and input is xy=01, the next state is  $A^+B^+=10$ .
- Also if the present state is AB and input is 10, the next state  $A^+ B^+ = 01$ .
- > In both cases present state and next state are not adjacent.
- A race free assignment can be obtained if we add an extra row to the flow table.
- > The first three rows represent the same conditions as the original three –row table.
- > The fourth row is assigned with 11.
- Now the transition of 01 to 10 for input xy=01 must go through 11.
- Also the transition of 10 and 01 for input xy=10 must go through 11.

| Present State              | Next State A <sup>+</sup> B <sup>+,</sup> Output Z |       |       |       |
|----------------------------|----------------------------------------------------|-------|-------|-------|
|                            | xy=00                                              | xy=01 | xy=11 | xy=10 |
| <b>S</b> <sub>0</sub> (00) | 00, 0                                              | 00, 0 | 10, - | 01, - |
| <b>S</b> <sub>1</sub> (01) | 00, -                                              | 11, - | 01, 0 | 01, 0 |
| S <sub>2</sub> (10)        | 00, -                                              | 10,1  | 10,1  | 11, - |
| <b>S</b> <sub>3</sub> (11) | -, -                                               | 10, - | -, -  | 01, - |

#### Table: Race free assignment

Since the present states and next states differ by single bit, the circuit for this flow table will be free from races.

#### Incompletely Specified State Machines

- Sequential circuits in which some of the states are left unspecified are called Incompletely Specified State Machines.
- > In sequential circuits, not all combinations of states and inputs are possible.
- ➢ For example, consider the state table is shown below.

| Present State      | Next State | Output Z |  |  |
|--------------------|------------|----------|--|--|
| Tresent State      | X=0        | X=1      |  |  |
| a                  | d, 1       | b, 0     |  |  |
| b                  | -, -       | c, 0     |  |  |
| с                  | a,1        | b, -     |  |  |
| d                  | a, o       | d, 1     |  |  |
| Table: State Table |            |          |  |  |

- Here the state 'b' will never receive a '0' input and hence the next state and outputs are left unspecified by a dash (-).
- In some situation, the state transitions are completely defined but for some combinations of states and inputs, the output values may be left specified.
- > In the state table, the next state of 'c' is specified as 'b' for the input '1' but the output is unspecified as dash.
- > When the state transition is unspecified, the future behavior of the sequential machine may become unpredictable.

\*\*\*\*\*

#### HAZARDS

*Explain in detail about hazards.* (*May 2012, May 2013, May 2011, Dec 2011, Dec 2012, Dec. 2013, May 2010, May 2009*) (Dec 2018

- Hazards are unwanted switching transients that may appear at the output of a circuit because different paths exhibit different propagation delays.
- > Hazards occur in combinational circuits, where they may cause a temporary false output value.
- > But in asynchronous sequential circuits hazards may result in a transition to a wrong stable state.

#### Types of Hazards

- ✓ Static Hazard
- ✓ Dynamic Hazard
- ✓ Essential Hazard

#### **Static Hazard**

- Static Hazard is a condition which results in *a single momentary incorrect output* due to change in a single input variable when the output is expected to remain in the same state.
- $\blacktriangleright$  The static hazard may be either static-0 or Static -1.

#### Hazards in Combinational Circuits

A hazard is a condition in which a change in a single variable produces a momentary change in output when no change in output should occur.



#### Fig: Circuits with Hazards

- ➤ Assume that all three inputs are initially equal to 1.
- This causes the output of gate 1 to be 1, that of gate 2 to be 0 and that of the circuit to be 1.

- Now consider a change in  $x_2$  from 1 to 0.
- Then the output of gate 1 changes to 0 and that of gate 2 changes to 1, leaving the output at 1.
- However, the output may momentarily go to 0 if the propagation delay through the inverter is taken into consideration.
- The delay in the inverter may cause the output of gate 1 to change to 0 before the output of gate 2 changes to 1.
- > The two circuits shown in Fig implement the Boolean function in sum-of-products form:

$$Y = x_1 x_2 + \overline{x_2} x_3$$

- > This type of implementation may cause the output to go to 0 when it should remain a 1.
- > If however, the Circuit is implemented instead in product-of-sums form namely,

$$Y = (x_1 + \overline{x_2})(x_2 + x_3)$$

then the output may momentarily go to 1 when it should remain 0.

- > The first case is referred to a static 1-hazard and the second case as static 0-hazard.
- A third type of hazard, known as **dynamic hazard**, causes the output to change three or more times when it should change from 1 to 0 or from 0 to 1.



#### Fig: Types of hazards

- > The change in  $x_2$  from 1 to 0 moves the circuit from minterm 111 to minterm 101.
- The hazard exists because the change in input results in a different product term covering the two minterm.



Fig: Illustrates hazard and its removal

- Minterm 111 is covered by the product term implemented in gate 1 and minterm 101 is covered by the product term implemented in gate 2.
- The remedy for eliminating a hazard is to enclose the two minterms with another product term that overlaps both groupings.
- > The hazard-free circuit obtained by such a configuration is shown in figure below.
- > The extra gate in the circuit generates the product term  $x_1x_3$ .
- In general, hazard s in combinational circuits can be removed by cove ring any two minterms that may produce a hazard with a product term common to both.
- > The removal of hazards requires the addition of redundant gates to the circuit.



#### Hazards in Sequential Circuits:



Fig: Hazard in an Asynchronous sequential circuit

- In normal combinational-circuit design associated with synchronous sequential circuits, hazards are of no concern, since momentary erroneous signals are not generally troublesome.
- However, if a momentary incorrect signal is fed back in an asynchronous sequential circuit, it may cause the circuit to go to the wrong stable state.
- > If the circuit is in total stable state  $yx_1x_2 = 111$  and input  $x_2$  changes from I to 0, the next total stable state should be 110.
- ▶ However, because of the hazard, output Y may go to 0 momentarily.
- If this false signal feeds back into gate 2 before the output of the inverter goes to 1, the output of gate 2 will remain at 0 and the circuit will switch to the incorrect total stable state 010.
- > This malfunction can be eliminated by adding an extra gate.

#### **Essential Hazards**

- Essential hazard is caused by unequal delays along two or more paths that originate from the same input.
- An excessive delay through an inverter circuit in comparison to the delay associated with the feedback path may cause such a hazard.

- > Essential hazards cannot be corrected by adding redundant gates as in static hazards.
- The problem that they impose can be corrected by adjusting the amount of delay in the affected path.
- To avoid essential hazards, each feedback loop must be handled with individual care to ensure that the delay in the feedback path is long enough compare d with delays of other signals that originate from the input terminals.

\*\*\*\*\*



Solution:-

 $P_A = (x \oplus y) \oplus A$ 

8 fep 2 :- plot the Fransition table

| ĩ | IPS 1 | present ] | Next     | Flip Flop |
|---|-------|-----------|----------|-----------|
| r | y     | State A'  | state At | FIPS D'   |
| 0 | 0     | 0         | 0        | 0 -       |
| 0 | 0     | (         | 1        | 1         |
| 0 | 1     | 0         | 1        | 1 ~       |
| 0 | •     | 1         | 0        | 0         |
| 1 | Ø     | 0         | 1        | 1-        |
| 1 | Ø     | 1         | 0        | 0 ~       |
|   | )     | 0         | 0        | 07        |
| 1 | 1     | 4         | 1        | 1~        |
| 1 | 2     | 1 Honda   | 1        | 1         |

(on trange ps in st columnas o'or i'

PREADENT YOULEX MYPE MEMORINAL



Step 1:- Determine the Flip Flop ifp eq. and off equivation.  
if eq.:- 
$$J_A = B$$
;  $L_A = B\overline{X}$   
 $J_B = \overline{X}$ ;  $L_B = \overline{X} \oplus A$   
 $off$  eq.:-  $F = A \oplus B$ 

Step 2:- plot the Frankton Fable

| Present | sfate | input | nleal | rstate         | Fli | p≠6 | p i p | 2. | 0]1 |
|---------|-------|-------|-------|----------------|-----|-----|-------|----|-----|
| A       | B     | x     | At    | B <sup>+</sup> | Jø  | ka  | JB    | KB | F   |
| 0       | 0     | 0     | 0     | 1              | 0   | 0   | 1     | 0  | 0   |
| O       | 0     | - 1   | 0     | 0              | 0   | 6   | 0     | 1  | 0   |
| 0       | 1     | 0     | 1     | 1              | -)  | t   | 1     | 6  | 3   |
| 0       | 1     | J     | 7     | 0              | -)  | O   | 0     | t  | 1   |
| 1       | 0     | O     | 1     | ) —            | 0   | 0   | ١     | 1  | 1   |
| ١       | 0     | 1     | ١     | 0              | 0   | Ö   | 0     | 0  |     |
| 1       | 1     | 0     | 0     | 0              | 1   | 1   | 1     | 5  | 0   |
| ١       | )     | )     | 1     | 1              | 1   | 0   | 0     | 0  | 0   |
|         |       | 1     |       |                |     |     |       |    |     |

. ,

| O             | Alext | -state. | 0 [p |     |
|---------------|-------|---------|------|-----|
| Present state | 2=0   | x=1     | X=D  | X=1 |
| . Q           | b     | Q       | 0    | 0   |
| 6             | d     | C       | 1    | )   |
| e             | d     | C       | )    | )   |
| d J           | a     | d       | 0    | 10  |



\* Flu analysis of public mode sequential about is same  
as that of Annolamental mode sequential avail.  
Step 1:- Determine the next state equations and op equations  
Next state eqs:- 
$$Y_1 = D_1$$
 :  $D_1 = Y_2 + Y_1 + Y_2$   
 $Y_2 = D_2$   $D_2 = \pi y_1 + y_2$   
 $Op equation :.$ 

.

1.1

$$Z = x \overline{y_1}$$

Step 1: plot the French Rable.

| ip 1 | p resent | states | alext | states | Olp Z | states.   |
|------|----------|--------|-------|--------|-------|-----------|
| a    | y.       | 9,     | Y2    | У,     | .7    |           |
| 0    | O        | 0      | ٢     | 0      | 0     | stable    |
| 0    | 0        | )      | 0     | 0      | 0     | anstable  |
| 0    | 1        | 0      | 1     | )      | 0     | sunsfab ( |
| 0    | 1        | )      | 1     | J      | 0     | stable    |
| 1 1  | 0        | 0      | 1     | 0      | 1     | unstabl   |
| 1    |          | ,      | 0     | 0      | 0     | anotab    |
|      |          | 0      | 1     | Õ      | 1     | Stable    |
|      |          | 1      | 1     | 1      | 0     | Stable    |



Design an asynchronous sequential circuit that has two inputs X<sub>2</sub> and X<sub>1</sub> and one output Z. the output is to remain a 0 as long as X<sub>1</sub> is 0. The first change in X<sub>2</sub> that occurs while X<sub>1</sub> is a 1 will cause output Z to be 1. The output Z will remain 1 until X returns to 0.(Dec 2013)(May 2014)
 Solution: [NOV 2020]

| States | Inputs<br>X <sub>2</sub> X <sub>1</sub> | Outputs<br>Z | Comments                |
|--------|-----------------------------------------|--------------|-------------------------|
| а      | 0 0                                     | 0            | after $b$ or $c$ or $f$ |
| b      | 1 0                                     | 0            | after a or d or e       |
| c      | 0 1                                     | 0            | after a                 |
| d      | 1 1                                     | 0            | after b                 |
| e      | 1 1                                     | 1            | after $c$ or $f$        |
| f      | 0 1                                     | 1 .          | after d or e            |

Step 2: Primitive flow table.

|         |    | 00     | Input X<br>01 | 2 X <sub>1</sub> | 10       |
|---------|----|--------|---------------|------------------|----------|
|         | a  | (a), 0 | c, 0          | -, -             | b, 0     |
|         | ь  | a,0    | -,-           | d, 0             | (b), 0   |
| Present | с  | а,0    | ©,0           | е, -             | 27       |
| State   | d  | - , -  | f, -          | 0, 🕲             | b, 0     |
|         | e. | - , -  | f, 1          | @,1              | b, -     |
|         | f  | a , -  | ①,1           | e, 1             | · -, - , |

Step 3: A reduced flow table is obtained using implication table and merger diagram.

| ъ   | 1         |          |              |                                                  |
|-----|-----------|----------|--------------|--------------------------------------------------|
| c   | 1         | d,e<br>X |              |                                                  |
| đ   | c, f<br>X | 1        | c,fX<br>d,eX | tan ing panaharan dari<br>Tan ing panaharan dari |
| 0   | ×         | ×        | ×            | ×                                                |
| . 1 | ×         | ×        | ×            | ×                                                |
|     | a         | b        | ¢            | e b                                              |

- > The compatible pairs are (a,b)(a,c)(b,d)(e,f)
- > The merger diagram is used to find more compatible pairs.



- ➤ 4 separate lines are obtained.
- > The compatible pairs are again (a,b)(a,c)(b,d)(e,f).
- > If (a,b) compatible pair is removed, then the remaining pairs (a,c) (b,d) (e,f) covers all the 6 states.
- > Therefore the reduced flow table is as follows:



Step 4: In order to avoid critical race, one more stable state is added and values are assigned for states.

| Pr                      | esent sta             | te.                   | N                                              | ext State and o                                                            | output for $X_2 X_1$ inputs                 |                                  |  |  |
|-------------------------|-----------------------|-----------------------|------------------------------------------------|----------------------------------------------------------------------------|---------------------------------------------|----------------------------------|--|--|
|                         | <i>y</i> <sub>2</sub> | <i>y</i> <sub>1</sub> | .00                                            | 01                                                                         | 11                                          | 10                               |  |  |
| $S_0$ $S_1$ $S_2$ $S_3$ | 0<br>0<br>1<br>-1     | 0<br>1<br>1<br>0      | $(S_0), 0$<br>$S_0, 0$<br>$S_3, -$<br>$S_0, -$ | (S <sub>0</sub> ), 0<br>S <sub>2</sub> , -<br>(S <sub>2</sub> ), 1<br>-, - | $S_{3}, -$ $S_{1}, 0$ $S_{2}, 1$ $S_{2}, -$ | $S_{1}, 0$ $S_{1}, 0$ $S_{1}, -$ |  |  |







# <u>Two Marks</u> UNIT-4 ASYNCHRONOUS SEQUENTIAL CIRCUITS

# 1. What are classifications of sequential circuits?

The sequential circuits are classified on the basis of timing of their signals in to two types. They are

- Synchronous sequential
- Asynchronous sequential circuits

# 2. What is synchronous sequential circuit?

# (Dec 2013)

Synchronous Sequential circuits are circuits in which the signals can affect the memory elements

only at discrete instant of time

# 3. Define Asynchronous sequential circuit.

In asynchronous sequential circuits change in input signals can affect memory element at any instant of time.

# 4. Give the comparison between synchronous & Asynchronous sequential circuits. (Dec 2009)

| Synchronous sequential circuits        | Asynchronous sequential circuits.     |
|----------------------------------------|---------------------------------------|
| Memory elements are clocked flip-flops | • Memory elements are either unlocked |
|                                        | flip - flops or time delay elements.  |
| • Easier to design.                    | • More difficult to design.           |

# 5. What is Moore and Mealy circuit?

# (May 2009,Dec 2010,Dec 2007 ,May 2010,Dec 2011, May2011,May2012, Dec 2017)

Moore circuit is a network where the output depends only on the present state of the flip flops. Mealy circuit is a network where the output depends on both the present state of the flip flops and on the inputs.

# 6. What are the steps for the designing of asynchronous sequential circuit? (May 2017)

- ✓ Construction of a primitive flow table from the problem statement.
- $\checkmark$  Primitive flow table is reduced by eliminating redundant states using the state reduction
- ✓ State assignment is made
- $\checkmark$  The primitive flow table is realized using appropriate logic elements.

# 7. What is merger graph?

It contains the same number of vertices as the state table contains states. A line drawn between the two state vertices indicates each compatible state pair. Two states are incompatible if no connecting line is drawn.

#### 8. What is closed covering?

A Set of compatibles is said to be closed if, for every compatible contained in the set, all its implied compatibles are also contained in the set. A closed set of compatibles, which contains all the states of M, is called a closed covering.

#### 9. What is meant by state table?

For the design of sequential counters which deals with present states and next states. The table, which represents the relationship between present states and next states, is called state table.

#### 10. Define total state.

The combination of level signals that appear at the inputs and the outputs of the delays is called the total state of the circuit

#### **11. Define primitive flow table.**

It is defined as a flow table which has exactly one stable state for each row in the table. The design process begins with the construction of primitive flow table.

#### 12. What are the types of asynchronous sequential circuits ?

- 1. Fundamental mode circuits
- 2. Pulse mode circuits

# 13. Give the comparison between state Assignment Synchronous circuit and state assignment asynchronous circuit.

In synchronous circuit, the state assignments are made with the objective of circuit reduction. In asynchronous circuits, the objective of state assignment is to avoid critical races.

# 14. What is the difference between stable and unstable state in an asynchronous sequential circuit?

If the present state and next state are same then it is said to be stable state.

If the present and next states are different then it is said to be unstable state.

#### 15. What are the problems involved in asynchronous circuits?

The asynchronous sequential circuits have three problems namely

a. Cycle

b. Races

c. Hazards.

#### 16. What are races?

When two or more binary state variables change their value in response to a change in an input variable, race condition occurs in an asynchronous sequential circuit. In case of unequal delays, a race condition may cause the state variables to change in an unpredictable manner.

# (May 2012)

# (May 2011)

(May 2019

#### **17. Define non-critical race.**

#### (Dec 2010, Dec 2016)

If the final stable state that the circuit reaches does not depend on the order in which the state variable changes, the race condition is not harmful and it is called a non-critical race.

#### **18. Define critical race.**

### (Dec 2010,Dec 2014, Dec 2016, May 2016)

If the final stable state depends on the order in which the state variable changes, the race condition is harmful and it is called a critical race.

#### **19. What is a cycle?**

A cycle occurs when an asynchronous circuit makes transition through a series of unstable states. If a cycle does not contain a stable state, the circuit will go from one unstable to stable to another, until the inputs are changed.

### 20. What is fundamental mode circuit?

A transition from one stable state to another occurs only in response to a change in the input state. After a change in one input has occurred, no other change in any input occurs until the circuit enters a stable state. Such a mode of operation is referred to as a fundamental mode.

# 21. Write a short note on pulse mode circuit. [Nov/Dec 2021]

Pulse mode circuit assumes that the input variables are pulses instead of level. The width of the pulses is long enough for the circuit to respond to the input and the pulse width must not be so long that it is still present after the new state is reached.

#### 22. Compare Fundamental mode and Pulse mode circuit.

(Dec 2012)

| Fundamental mode                                 | Pulse mode circuit                                |
|--------------------------------------------------|---------------------------------------------------|
| Inputs are levels and not pulses.                | Input variables are pulses instead of levels      |
| Input variables changes only when the circuit is | The width of the pulses is long enough for the    |
| in stable                                        | circuit to respond to the input.                  |
| Only one input variable change at a given time.  | The pulse width must not be long that it is still |
|                                                  | present after the new state is reached.           |

### **23. Define secondary variables**

The delay elements provide a short term memory for the sequential circuit. The present state and next state variables in asynchronous sequential circuits are called secondary variables.

### 24. Define flow table in asynchronous sequential circuit.

In asynchronous sequential circuit state table is known as flow table because of the behavior of the asynchronous sequential circuit. The stage changes occur in independent of a clock, based on the logic propagation delay, and cause the states to flow from one to another.

#### **25.** What are the different techniques used in state assignment? (May 2016)

• Shared row state assignment

• One hot state assignment

# 26. What is the significance of state assignment?

In synchronous circuits-state assignments are made with the objective of circuit reduction. For Asynchronous circuits- its objective is to avoid critical races.

# 27. Define Race condition. How can it be avoided?

If an input changes in two or more feedback variables then it is known as race condition.

Races can be avoided by using a race free state assignment while designing the circuit.

# 28. Write short note on shared row state assignment.

Only one state variable can change at any one state variable can change at any one time when a state transition occurs. To accomplish this, it is necessary that states between which transitions occur be given adjacent assignments.

# 29. Write short note on one hot state assignment.

Only one variable is active or hot for each row in the original flow table, i.e., it requires one state variable for each row of the flow table. Additional row are introduced to provide single variable changes between internal state transitions. (May 2016) [NOV 2020]

#### (Dec 2009, May 2010, Dec 2013, May 2013, Dec 2015, Dec 2016&2017) **30. What is hazard?**

Unwanted switching transients that may occur in an output of combinational circuit is Called hazards

# 31. What happens when a hazard in a logic circuit?

In Combinational circuits, hazards may cause temporary false output. But in sequential circuits hazards may cause a transition to a wrong state.

#### **32.** What is static 1 hazard? [NOV 2020] (May 2009, Dec 2015, Dec 2013)

The output goes momentarily 0 when it should remain at 1 is called static 1 hazard

# **33.** What is static 0 hazard?

The output goes momentarily 1 when it should remain a t 0 is called static 0 hazard.

#### 34. What is dynamic hazard? (May 2018) (Dec 2019

The output changes 3 or more times when it changes from 1 to 0 or 0 to 1 is called dynamic hazard.

# 35. What is the cause for essential hazards?

Unequal delays along 2 or more path from same input cause essential hazards.

# 36. What are the basic elements of ASM chart?

An ASM chart mainly consists of three elements:

State box - one box per system state

*Decision box* - Basic condition, i.e. logic flow control. Only the decision boxes depend on inputs. *Conditional box*- An action/operation to be undertaken conditioned on some earlier decision box.

(Dec 2011)

(May 2017)

# (Dec 2013)(May 2009)

(Dec 2014, May 2011)

#### 37. What is Algorithmic State Machine (ASM)?

- $\checkmark$  An ASM is a flow chart representation that describes the behavior of a sequential circuit.
- ✓ An ASM chart differs from a conventional flow chart, a conventional flow chart describes the procedure steps and decision path for an algorithm without concern of their time relationship.
- $\checkmark$  An ASM chart also describes the timing relationship between the states and outputs.

## 38. What is state diagram?

It is the graphical representation of state table. In state diagram, a state is represented by a circle, and the transitions between the states are indicated by directed lines connecting circles.

### 39. What are hazard free digital circuits?

A circuit which has no hazard like static-0-hazard and static-1-hazard is called hazard free digital circuit.

# 40. Draw the general model of ASM.



#### (Dec 2014) (May 2013) (Dec 2015)

# ((Dec 2018)

[April/May-2010]

(May 2014)

#### Enumpre no

Design a negative edge triggered T flip-flop. The circuit has 2 inputs, T (toggle) and C (clock and outputs Q and  $\overline{Q}$ . The output state is complemented if T = 1 and the clock changes from 1 to 0. Otherwise under any other input condition, the output Q remains unchanged.

# Solution :

Step 1: A table with all possible total states in the system is formed. A primitive flow table is obtained from this table.

| States | Inputs |   | Outputs | Comments               |
|--------|--------|---|---------|------------------------|
|        | Т      | С | Q       |                        |
| a      | 1      | 1 | 0       | initial output is 0    |
| ь      | 1      | 0 | 1       | after state a          |
| с      | 1      | 1 | 1       | after output is 1      |
| d      | I      | 0 | 0       | after state $c$        |
| e      | 0      | 0 | 0       | after state $d$ or $f$ |
| f      | 0      | 1 | 0       | after state e or a     |
| g      | 0      | 0 | 1       | after state $b$ or $h$ |
| h      | 0      | 1 | 1       | after state g or c     |

**Primitive Flow Table** 

|         |   |               | T    | C              |      |
|---------|---|---------------|------|----------------|------|
|         |   | 00            | 01   | 11             | 10   |
|         | a | -, -          | f. – | <b>(a)</b> , 0 | b, - |
|         | b | g. –          | -,-  | c, -           | 6.1  |
| Prasent | c | -,-           | h,   | © 1            | d,   |
| State   | d | θ, -          | -,-  | a, -           | @, 0 |
|         | e | <b>()</b> , 0 | f,   |                | d, - |
|         | f | e, -          | ٥D   | a, -           | -,-  |
|         | g | <b>(</b> ), 1 | h. – | -, -           | b, - |
|         | h | g             | 6,1  | c, -           | -,-  |

Step 2: Reduced Flow Table is obtained using implication table and merger diagram.



The compatible pairs are (a, f) (b, g) (b, h) (c, h) (e, f) (g, h) (d, e) (d, f).

Merger Diagram



The maximal compatibles are (a, f)(c, h)(b, g, h)(d, e, f).

The reduced flow table is given below.



Step 3: A race free binary state assignment is made. Transition table and output map is obtained. Output Map **Transition Table** TC TC Y1 y2 ¥192 Х X X Х (11) X Х  $Q = y_2$ 

Step 4: Logic diagram.



| Y1 TC | 00 | 01 | 11 | 10 |
|-------|----|----|----|----|
| 0     | 1  | 0  | 0  | 0  |
| 0     | 0  | 0  | 1  | 0  |
| 1     | 0  | 1  | 1  | 1  |
| 1     | 1  | 1  | 0  | 1  |

Use SR latches.

The excitation table for SR latch is

| 0 | $Q_{n+1}$ | S | R |
|---|-----------|---|---|
| 0 | 0         | 0 | Х |
| 0 | 1         | 1 | 0 |
|   | 0         | 0 | 1 |
| 1 |           | x | 0 |

Map for  $Y_2$ 







т

 $R_2 = y_1 T \overline{C}$ 



Fig. 4.17: Logic diagram of Example 4.3

# Example:

Design an asynchronous sequential circuit with inputs  $\times 1$  and  $\times 2$  and one output z. Initially and at any time if both the inputs are 0, output is equal to 0. When  $\times 1$  or  $\times 2$  becomes 1, z becomes 1. When second input also becomes 1, z = 0; The output stays at 0 until circuit goes back to initial state.



| States | Inputs         |                | Outputs | Comments     |
|--------|----------------|----------------|---------|--------------|
|        | X <sub>2</sub> | X <sub>1</sub> | Z       |              |
| a      | 0              | 0              | 0       | after b or c |
| b      | 0              | 1              | 1       | after a      |
| c      | 1              | 0              | 1       | after a      |
| d      | 1              | 1              | 0       | after b or c |
| e      | ţ              | 0              | 0       | after d      |
| f      | 0              | 1              | 0       | after d      |

Step 2: Primitive flow table.

|   | 00 | 01  | 11        | 10   |
|---|----|-----|-----------|------|
| а | @0 | b - | · · , • · | с    |
| σ | ð  | 6)  | d         | · ·, |
| с | a, | ,   | d         | ©1   |
| đ | ,  | t,  | <u>ە</u>  | e,   |
| е | a, | ,   | ď         | @0   |
| f | a, | 00  | d         |      |

Step 3: A reduced flow table is obtained using Implication table and merger diagram.



The compatible pairs are (a, b) (a, c) (b, c) (b, e) (c, f) (d, e) (d, f) (e, f).

# Merger Diagram:



The Maximal Compatibles are (a, b, c) (d, e, f) (c, f) (b, e) (c, f) and (b, e) can be removed. Since the remaining terms themselves cover all six states.







 $Y = X_2 X_1 + y X_1 + y X_2$   $Z = \overline{y} X_1 + \overline{y} X_2$ .

10

1

0





#### \*\*\*\*\*\*\*\*\*\*

#### **Problems on hazards:**

Example

Give hazard free realization for the following Boolean functions.

 $f(A, B, C, D) = \sum m(1, 3, 6, 7, 13, 15).$ 

# Solution :

The simplified expression for the given function can be obtained using k-map.



The simplified expression is,

$$f(A, B, C, D) = \overline{ABD} + \overline{ABC} + \overline{ABD}$$

But to remove hazards, we have to include another two terms, which is shown in dotted lines in map.

 $f(A, B, C, D) = \overline{ABD} + \overline{ABC} + ABD + \overline{ACD} + BCD$ 

The logic diagram is as shown in Figure 4.38.



Fig. 4.38 : Logic diagram of Example 4.14

Example

Give hazard free realization for the following Boolean functions.

May 2017

isr

 $F(A, B, C, D) = \sum m(0, 1, 5, 6, 7, 9, 11).$ 

Solution :

The simplified expression for the given function can be obtained using K-map.

| АВ     |   | <u>C</u> D<br>ا | CD<br>11 | CD<br>10 |
|--------|---|-----------------|----------|----------|
| Ā 🖥 00 | 1 | 1               | 0        | 0        |
| ĀB 01  | 0 | 1               | (1)      | 1        |
| AB 11  | 0 | 0               | 0        | 0        |
| AB 10  | 0 | (1)             | 1        | 0        |
|        |   |                 |          |          |

The simplified expression is,

 $F = \overline{ABC} + \overline{ABD} + \overline{ABC} + \overline{ABD}$ 

But to remove hazards, we have to include two more terms, that are shown as dotted lines in K-map.



Fig. 4.39 : Logic diagram of Example 4.15

Example .

Give hazard free realization for the following Boolean function

 $F(I, J, K, L) = \sum m(1, 3, 4, 5, 6, 7, 9, 11, 15).$ 

Solution :

The simplified expression for the given function can be obtained using K-map.

| IJ KL  | K E<br>00 | KL<br> 01                                | KL<br>11 | К <u>Г</u><br>10 |
|--------|-----------|------------------------------------------|----------|------------------|
| 00 Ū Ī | 0         | 1                                        |          | 0                |
| ĪJ 01  | 1         | 1                                        | 1        | 1                |
| IJ 11  | 0         | 0                                        | 1        | 0                |
| ıJ 10  | 0         | 1                                        | 1        | 0                |
|        |           | 1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1.1. |          |                  |

The simplified expression is,

 $\mathbf{F} = \mathbf{\tilde{I}} \mathbf{J} + \mathbf{K} \mathbf{L} + \mathbf{\tilde{J}} \mathbf{L} \qquad \text{for all the set of the s$ 

But to remove hazards, one more redundant quad have to be included, which is shown as dotted lines in K-map.

Page 4

 $F = \overline{I}J + KL + \overline{J}L + \overline{I}L$ 



Fig. 4.40 : Logic Diagram of Example 4.16

# Example 4.17

Find a static and dynamic hazard free realization for the following function using

(i) NAND gates. (ii) NOR gates.

$$f(a, b, c, d) = \sum m(1, 5, 7, 14, 15).$$

#### & Solution :

The simplified expression for the given function can be obtained using K-map.

| ab | 00 | 01 | 11   | 10 |
|----|----|----|------|----|
| 00 | 0  | 1  | 0    | 0  |
| 01 | 0  | 1  | [1-] | 0  |
| 11 | 0  | 0  | 1    | 1  |
| 10 | 0  | 0  | 0    | 0  |

The simplified expression is,

4

 $f = \overline{acd} + \overline{abd} + abc$ 

But to remove static and dynamic hazards one more term has to be included, which is shown as dotted lines in K-map.

$$f = \overrightarrow{acd} + \overrightarrow{abd} + abc + bcd$$

This can be implemented using NAND gates as follows.





The above expression can also be implemented using NOR gates, as shown in Figure 4.40.



#### **Problem:**

A staircase light is controlled by two switches one at the top of the stairs and another at the bottom of stairs a. Make a truth table for this system. (May 2018)

b. Write the logic equation is SOP form.

c. Realize the circuit using AND-OR gates.

Solution:

a. The truth table for the system is illustrated in given truth table

| А | В | Light |
|---|---|-------|
| 0 | 0 | 0     |
| 0 | 1 | 1     |
| 1 | 0 | 1     |
| 1 | 1 | 0     |

- b. The logic equation for given system is specified by L = A' B + A B'
- c. Realization of given case, the circuit using AND-OR gates is demonstrated in fig



<sup>\*\*\*\*\*\*\*\*\*\*\*\*\*</sup> 

\* Differentiate dynamic hazard and static hazard. [NOV/DEC 2021]

# ° Static 1-hazard

Input change causes output to go from 1 to 0 to 1

# ° Static 0-hazard

Input change causes output to go from 0 to 1 to 0

# ° Dynamic hazards

 Input change causes a double change from 0 to 1 to 0 to 1 OR from 1 to 0 to 1 to 0







An asynchronous sequential circuit has two internal states and one output. The two excitation functions and one output function describing the circuit are, respectively.

 $Y_1 = x_1x_2 + x_1y_2' + x_2'y_1$  $Y_2 = x_2 + x_1y_1'y_2 + x_1'y_1$  $Z = x_2 + y_1$ 

Draw the logic diagram of the circuit. Obtain the transition table, flow table and output map for the circuit. [NOV / DEC 2021]





Obtain the binary state assignment for the reduced flow table shown in Fig. 1. Avoid critical race conditions. Also draw the logic diagram of the circuit using NAND latches and gates. [NOV / DEC 2021]



48





Design an asynchronous circuit using positive edge triggered JK flip-flops with minimal combinational gating to generate the following sequence 0-1-2-0; if input X = 0 and 0-2-1-0; if input X = 1, provide an output which goes high to indicate the non-zero state in the 0-1-2-0 sequence. Is this a mealy machine? [NOV / DEC 2021]

00 Ko/6. 16 A 0/1 Excitation table 1/0 RA QA J K 0 0 0 X 0 1 1 X Otate table & Excitation table 1.0 X 1 X 0 PreventInput<br/>StateNext StateJkJkStateX $Q_A^+$  $Q_B^+$  $J_A$ kJkg $Q_0$ 010X1X1OO010XX0OO010XX0OO010XX0OO010XX1OO010X10OO100X10OO00X10X0OO100X10OO100X10OO100X10OO100X10OO10X1X0OO10X1X0OO10X1X0 K-MAP JA X JAPB 00 01 11  $J_{A} = \overline{\chi} Q_{B} + \chi Q_{B}$  $= \chi \bigoplus Q_{B}$ 



# UNIT V

# MEMORY DEVICES AND DIGITAL INTEGRATED CIRCUITS

Basic memory structure – ROM -PROM – EPROM – EEPROM –EAPROM, RAM – Static and dynamic RAM - Programmable Logic Devices – Programmable Logic Array (PLA) - Programmable Array Logic (PAL) – Field Programmable Gate Arrays (FPGA) – Implementation of combinational logic circuits using PLA, PAL.

Digital integrated circuits: Logic levels, propagation delay, power dissipation, fan-out and fanin, noise margin. logic families and their characteristics-RTL. TTL. ECL. CMOS

# **CLASSIFICATION OF MEMORIES**

# Discuss the classification of ROM and RAM memories.(Dec 2017),( May 2006,12,13,15), Dec 2013)

- A memory unit is a device to which binary information is transferred for storage and from which information is retrieved when needed for processing.
- When data processing takes place, information from memory is transferred to selected registers in the processing unit.
- > A memory unit is a collection of cells capable of storing a large quantity of binary information.

# **TWO TYPES OF MEMORIES:**

- > There are two types of memories that are used in digital systems:
  - o Random-access memory (RAM) and Read-only memory (ROM)

### (i) Random-access memory (RAM)

- ✓ RAM stores new information for later use.
- ✓ The process of storing new information into memory is referred to as a memory "write" operation.
- ✓ The process of transferring the stored information out of memory is referred to as a memory *"read"* operation.
- $\checkmark$  RAM can perform both write and read operations.

### (ii) Read-only memory (ROM)

- $\checkmark$  ROM can perform only the read operation.
- ✓ This means that suitable binary information is already stored inside memory and can be retrieved or read at any time.
- $\checkmark$  However, that information cannot be altered by writing.
- > ROM is a *programmable logic device* (PLD).
- The binary information that is stored within such a device in some fashion and then embedded within the hardware in a process is referred to as *programming* the device.

\*\*\*\*\*

### **TYPES OF ROM**

### Briefly explain EPROM and EEPROM technology.

The required paths in a ROM may be programmed in four different ways.

- > Mask programming
  - $\checkmark$  It is done by the semiconductor company during the *last fabrication process* of the unit.
  - ✓ This procedure is costly because the *vendor charges the customer a special fee* for custom masking the particular ROM.

### > Programmable read-only memory- PROM.

- ✓ Economical for small quantity.
- ✓ The fuses in the PROM are blown by the application of a high-voltage pulse to the device through a special pin.
- $\checkmark$  A blown fuse defines a binary 0 state and an intact fuse gives a binary 1 state.
- ✓ The procedure is irreversible and once programmed; the fixed pattern is permanent and cannot be altered.

### Erasable PROM or EPROM

- ✓ This can be restructured to the initial state even though it has been programmed previously.
- ✓ It is *erased* by placing under a special *ultraviolet light* for a given length of time.

### > Electrically erasable PROM (EEPROM) or Electrically Alterable PROM (EAPROM)

- ✓ Electrical signals are used to erase the previously programmed connections instead of ultraviolet light.
- $\checkmark$  The advantage is that the device can be erased without removing it from its socket.

### > EAPROM stands for Electronically Alterable Programmable Read-Only Memory.

- $\checkmark$  It is a type of PROM whose contents can be changed.
- ✓ It acts as a non-volatile storage device, and its individual bits can be re-programmed during the course of system operation.
- ✓ There are some timing constraints that cause the part to need more time for erasure or programming then is needed to read data from the part.

\*\*\*\*\*

# Draw the basic circuit of a Rom cell and describe its working principle with its architecture. [NOV 2020] READ-ONLY MEMORY(ROM)

### Explain in detail about read-only memory.

### (May 2013, May 2011, Dec 2009, Dec 2011)

- ▶ ROM is a non-volatile memory. It can hold data even if power is turned off.
- > A ROM is essentially a memory device in which permanent binary information is stored.
- > It is embedded in the unit and cannot be altered.
- ▶ It consists of 'k' inputs and 'n' outputs.



Fig: ROM block diagram

### **ROM Organization:**

- The inputs provide the address for memory, and the outputs give the data bits of the stored word that is selected by the address.
- Number of words is get from number of address inputs, here it is 'k', hence 2<sup>k</sup> words of n bits each is present in the memory.



Fig: Internal logic of a 32×8 ROM

### Example:

- The five inputs are decoded into 32 distinct outputs by means of a 5×32 decoder. Each output of the decoder represents a memory address.
- The 32 outputs of the decoder are connected to each of the eight OR gates. Each OR gate must be considered as having 32 inputs.

- Each output of the decoder is connected to one of the inputs of each OR gate.
- Since each OR gate has 32 input connections and there are 8 OR gates, the ROM contains 32 x 8 = 256 internal connections.
- A programmable connection between *two lines* is logically equivalent to a switch that can be altered to be either *closed* (two lines are connected) or *open* (two lines are disconnected).
- > The programmable intersection between two lines is sometimes called a *cross point*.

| Inputs |    |                | Outputs |                |    |                |                |                |                |    |                |   |
|--------|----|----------------|---------|----------------|----|----------------|----------------|----------------|----------------|----|----------------|---|
| 1.4    | 13 | I <sub>2</sub> | 1       | I <sub>0</sub> | A7 | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | Az | A <sub>1</sub> | A |
| 0      | 0  | 0              | 0       | 0              | 1  | 0              | 1              | 1              | 0              | 1  | T              | 0 |
| 0      | 0  | 0              | 0       | 1              | 0  | 0              | 0              | 1              | 1              | 1  | 0              | 1 |
| 0      | 0  | 0              | 1       | 0              | 1  | 1              | 0              | 0              | 0              | 1  | 0              | 1 |
| 0      | 0  | 0              | 1       | 1              | 1  | 0              | 1              | 1              | 0              | 0  | I              | 0 |
| 1      | 1  | 1              | 0       | 0              | 0  | 0              | 0              | 0              | 1              | 0  | 0              | 1 |
| 1      | 1  | 1              | 0       | 1              | 1  | 1              | 1              | 0              | 0              | 0  | 1              | 0 |
| 1      | 1  | 1              | 1       | 0              | 0  | 1              | 0              | 0              | 1              | 0  | 1              | 0 |
| 1      | 1  | 1              | 1       | 1              | 0  | 0              | 1              | 1              | 0              | 0  | 1              | 1 |

ROM Truth Table (Partial)

- > For an example, programming the ROM according to the truth table given by table.
- Every 0 listed in the truth table specifies the *absence* of a connection and *every 1* listed specifies a path that is *obtained* by a connection.



\*\*\*\*\*

### RANDOM ACCESS MEMORY(RAM)

### Explain in detail about Random Access Memory.

- RAM stores new information for later use.
- > The process of storing new information into memory is referred to as a memory *write* operation.
- The process of transferring the stored information out of memory is referred to as a memory *read* operation.
- > RAM can perform both write and read operations.

### **RAM Organization:**

A block diagram of a memory unit is shown in Fig.



- The *n* data input lines provide the information to be stored in memory, and the *n* data output lines supply the information coming out of memory.
- > The k address lines specify the particular word chosen among the many available.
- > The two control inputs specify the direction of transfer desired: *Write* input and *Read* input.
- A memory unit stores binary information in groups of bits called words.
- Each word in memory is assigned an identification number called an address starting from 0 up to 2<sup>k</sup>-1. where k is the number of address lines.
- Consider for example, a memory unit with a capacity of 1K words of 16 bits each. Since
- Here 1024 x 16 RAM consists of 10 x 1024 decoder (1K=1024bytes = 2<sup>10</sup>), where the decoder inputs are the 10 address lines.
- > The decoder accepts the address lines and provides the path needed to select the word specified.

| Memory a   | address |                  |
|------------|---------|------------------|
| Binary     | Decimal | Memory content   |
| 0000000000 | 0       | 1011010101011101 |
| 0000000001 | 1       | 1010101110001001 |
| 0000000010 | 2       | 0000110101000110 |
|            | 1       |                  |
| 111111101  | 1021    | 1001110100010100 |
| 1111111110 | 1022    | 0000110100011110 |
| 1111111111 | 1023    | 1101111000100101 |

### Fig: Contents of a $1024 \times 16$ memory

### Read and write operations:

> The two operations that RAM can perform are the write and read operations.

### Steps to Write operation as follows:

- $\checkmark$  Apply the binary address of the desired word to the address lines.
- $\checkmark$  Apply the data bits that must be stored in memory to the data input lines.
- ✓ Activate the *write* input.

### Steps to Read operation as follows:

- $\checkmark$  Apply the binary address of the desired word to the address lines.
- $\checkmark$  Activate the *read* input.
- The *memory enable or chip select* is used to enable the particular memory chip in a multichip implementation of a large memory.

| ontion inputs to memory citip |            |                         |  |  |  |  |  |
|-------------------------------|------------|-------------------------|--|--|--|--|--|
| Memory Enable                 | Read/Write | Memory Operation        |  |  |  |  |  |
| 0                             | х          | None                    |  |  |  |  |  |
| 1                             | 0          | Write to selected word  |  |  |  |  |  |
| 1                             | 1          | Read from selected word |  |  |  |  |  |

Control Inputs to Memory Chip

When the memory enable is inactive, the memory chip is not selected and no operation is performed. When the memory enable input is active, the read/write operation to be performed.

### Memory Cycle and Timing Waveforms:

### With neat timing diagram, explain the write and read operations.

- > The operation of the memory unit is controlled by an external device such as a central processing unit (CPU).
- > The CPU is usually synchronized by its own clock.
- > The access time of memory is the time required to select a word and read it.
- > The cycle time of memory is the time required to complete a write operation.



Fig: Memory read cycle timing waveform

> The memory- enable and read/write signals must be in their high level for a read operation.



### Fig: Memory write cycle timing waveform

The memory enable signal switches to the high level and the read/write signal switches to the low level to indicate a write operation.

\*\*\*\*\*\*\*\*

(May 2009)

### **TYPES OF RAM**

### Explain the types of RAM with neat diagram.

(Dec 2011) (May-2010)(May 2018) (Dec 2018

RAM is classified into two types.

- 1. Static RAM
- 2. Dynamic RAM

### STATIC RAM (SRAM):

- Memories that consist of circuits capable of *retaining their state as long as power is applied* are known as static memories.
- Two basic SRAM cell technologies are
  - Bipolar and MOS.
- > All those types use cross-coupled transistors to make up the basic flip-flop storage cell.

### Bipolar Static RAM cell:

- > It is implemented using TTL (Transistor-Transistor Logic) multiple emitter technology.
- > It can store either 0 or 1 as long as power is applied.

### **Operation:**

- Row and column select lines select a cell.
- > The Q1 and Q2 are cross coupled inverters.
- ➤ A "1" is stored in the cell if Q1 is ON and Q2 is OFF.
- ➤ A "0" is stored in the cell if Q2 is ON and Q1 is OFF.
- ➤ When pulsing HIGH on Q1 emitter (SET), State is changed to '0'.
- ➤ When pulsing HIGH on Q2 emitter (RESET), State is changed to '1'





b. MOS SRAM cell

### **Operation:**

- > In the basic NMOS cell,  $Q_1$  and  $Q_2$  are always biased to act as a Load Resistor for  $Q_3$  and  $Q_4$ .
- > The Data in a cell can be read by setting *ROW\_SELECT* = 1 to turn on Pass Transistors  $Q_5$ ,  $Q_6$ .
- > The Data from cell is then "passed" to the *BIT* Line and (BIT)' Line.
- To store a '0', place a 0 on the bit line and set  $ROW\_SELECT = 1$ . This turns on the Pass Transistors ( $Q_5, Q_6$ ) to place a 0 to  $Q_4$  (it is off).  $Q_3$  is then ON to store the 0.
- A '1' can be stored in a similar fashion.

### Dynamic RAM cell:

### Write note on dynamic RAM cell.

- > Dynamic RAM (DRAM) stores data as *a charge on capacitors*.
- The stored charge on the capacitors tends to discharge with time, and the capacitors must be periodically recharged by refreshing the dynamic memory.
- Refreshing is done by cycling through the words every few milliseconds to restore the decaying charge.
- > DRAM offers *reduced power consumption and larger storage capacity* in a single memory chip.
- Memory units that lose stored information when power is turned off are said to be *volatile*.

### (Dec 2005, May 2014)



\*\*\*\*\*

### Comparison of Static and Dynamic RAM.

### (May 2009, May 2017)

> Integrated circuit RAM units are available in two operating modes: *static and dynamic*.

| S.No | Static RAM                                                                     | Dynamic RAM                                                                                                            |
|------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|
| 1    | Static RAM contains less memory cells per<br>unit area                         | Dynamic RAM contains more memory cells as compared to static RAM per unit area.                                        |
| 2    | It has less access time hence faster memories.                                 | Its access time is greater than static RAMs.                                                                           |
| 3    | Static RAM consists of number of flip<br>flops. Each flip flop stores one bit. | Dynamic RAMs store the data as a charge on<br>the capacitor. It consists of MOSFET and the<br>capacitor for each cell. |
| 4.   | Refreshing circuitry is not required.                                          | Refreshing circuitry is required to maintain the<br>charge on the capacitors after every few<br>milliseconds           |
| 5    | Cost is more                                                                   | Cost is less                                                                                                           |

\*\*\*\*\*\*

### PROGRAMMABLE LOGIC DEVICES (PLDs)

Write brief notes on combinational programmable logic device PLD.

### **Combinational PLDs**

- The PROM is a combinational programmable logic device (PLD)-an integrated circuit with programmable gates divided into an AND array and an OR array to provide an AND-OR sum of- product implementation.
- There are three major *types of combinational PLDs*, differing in the placement of the programmable connections in the AND-OR array.

- 1. PROM- Fixed AND array and a programmable OR array.
- 2. PAL Programmable AND array and a fixed OR array.
- 3. PLA Programmable AND array and a programmable OR array.



### Write short notes on PLA.

- (Dec 2019
- Programmable logic arrays (PLAs) is a type of fixed architecture logic devices with programmable AND gates followed by programmable OR array.
- > PLA is used to implement a complex combinational circuit.
- > The AND and OR gates inside the PLA are initially fabricated with fuses among them.
- The specific Boolean functions are implemented in sum of products (SOP) form by blowing appropriate fuses and leaving the desired connections.
- ➢ For an example, the Boolean expressions are,

$$F_1 = A\bar{B} + AC + \bar{A}B\bar{C}$$

$$F_2 = \overline{(AC + BC)}$$



Fig: PLA with three inputs, four product terms and two outputs

- The fuse map of a PLA can be specified in a tabular form. The first section lists the product terms numerically.
- > The second section specifies the required paths between inputs and AND gates.
- The third section specifies the paths between the AND and OR gates. For each output variable, we may have a T'(for true) or C (for complement) for programming the XOR gate.
- ➢ For each product term, the inputs are marked with 1, 0, or (dash). If a variable in the product term *appears* in the form in which it is true, the corresponding input variable is *marked with a 1*.
- If it *appears complemented*, the corresponding input variable is *marked with a 0*. If the variable is absent from the product term, it is marked with a dash.

|                 |              |   | Input | ts | Out<br>(T) | puts<br>(C) |
|-----------------|--------------|---|-------|----|------------|-------------|
|                 | Product Term | A | B     | с  | F7         | F2          |
| AB'<br>AC<br>BC | 1            | 1 | 0     | _  | 1          | -           |
| AC              | 2            | 1 | -     | 1  | 1          | 1           |
| BC              | 3            | - | 1     | 1  |            | 1           |
| A'BC'           | 4            | 0 | 1     | 0  | 1          |             |

#### PLA Programming Table

\*\*\*\*\*\*

# I combinational circuit is defined by the fine fine

FICA, B, C) = S(3,5,6,7) F, (A, B, C) = & (0,2,4,7) Implement the circuit with PLA housing 3 it's , & Product towns and 2 ofp's with True & complement. 501.





Step2. PLA Table

|                | Product Tom             |   | 1 IP'S |            | P  | 1.1. |     |
|----------------|-------------------------|---|--------|------------|----|------|-----|
|                | r a would of a contract | A | B      | C          | F1 | 1    | -   |
| BC             | 1                       | _ | 0      | 0          | 11 | F2   | -   |
| BC<br>AC<br>AB | 2                       | 0 |        | $\bigcirc$ |    |      |     |
| ĀB             | 3                       | 0 | 0      | _          |    | 1    |     |
| ABC            | 4                       | 1 | 1      | Ţ          | -  | -    |     |
|                |                         |   |        |            | С  | T    | TIC |



### **\*** Implement the following two Boolean functions with a PLA: (May 2012, May 2014, Dec 2013)

 $F_1(A, B, C) = \sum (0, 1, 2, 4)$  $F_2(A, B, C) = \sum (0, 5, 6, 7)$ 

#### Solution:

Kmap

|                        | PLA                                     | programmir                                          | ng table                                                                                                                                     | $\sum BC$                                                   |                          |                                                       | B                                                | B                                                 | С                                                |                          |                                                       | B                                                |
|------------------------|-----------------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|--------------------------|-------------------------------------------------------|--------------------------------------------------|---------------------------------------------------|--------------------------------------------------|--------------------------|-------------------------------------------------------|--------------------------------------------------|
| AB<br>AC<br>BC<br>A'B' | Product<br>term<br>1<br>2<br>3<br>CC' 4 | Inputs<br>A B C<br>1 1 -<br>1 - 1<br>- 1 1<br>0 0 0 | $\begin{array}{ccc} \text{Outputs} \\ \text{(C)} & \text{(T)} \\ \hline F_1 & F_2 \\ \hline 1 & 1 \\ 1 & 1 \\ 1 & - \\ - & 1 \\ \end{array}$ | $ \begin{array}{c} A \\ 0 \\ 0 \\ A \\ 1 \\ 1 \end{array} $ | 01<br>m1<br>1<br>m5<br>0 | 11<br>m <sub>3</sub><br>0<br>m <sub>7</sub><br>0<br>C | 10<br>m <sub>2</sub><br>1<br>m <sub>6</sub><br>0 | $ \begin{array}{c} A \\ 0 \\ A \\ 1 \end{array} $ | 00<br>m <sub>0</sub><br>1<br>m <sub>4</sub><br>0 | 01<br>m1<br>0<br>m5<br>1 | 11<br>m <sub>3</sub><br>0<br>m <sub>7</sub><br>1<br>C | 10<br><sup>m</sup> 2<br>0<br><sup>m</sup> 6<br>1 |

### **Boolean Expressions:**

 $F_1 = (AB + AC + BC)' \qquad F_2 = AB + AC + A'B'C'$ 

### **PLA Diagram:**





#### \*\*\*\*\*

(May 2019)

### **Problems using PROM:**

Design a large circuit for the following Boolean expressions using PROM.

$$F_{1}(x, y, z) = \sum m(1, 2, 4, 7).$$
  
$$F_{2}(x, y, z) = \sum m(3, 5, 6, 7).$$

### Solution :

The Truth Table for the functions  $F_1$  and  $F_2$  are given below.

| a ann an Star a | Inputs | Outp | uts              |                |
|-----------------------------------------------------------------------------------------------------------------|--------|------|------------------|----------------|
| x                                                                                                               | у      | z    | $\mathbf{F}_{1}$ | F <sub>2</sub> |
| 0                                                                                                               | 0      | 0    | 0                | 0              |
| 0                                                                                                               | 0      | 1    | 1                | 0              |
| 0                                                                                                               | 1      | 0    | 1                | 0              |
| 0                                                                                                               | 1      | 1    | 0                | 1              |
| 1                                                                                                               | 0      | 0    | 1                | 0              |
| 1                                                                                                               | 0      | 1    | 0                | 1              |
| 1                                                                                                               | 1      | 0    | 0                | 1              |
| 1                                                                                                               | 1      | 1    | 1                | 1              |

The PROM implementation is given below.



### PROGRAMMABLE ARRAY LOGIC (PAL):

#### Write short notes on PAL.

### (Dec2011,Nov-2016)

- ➤ The PAL is a programmable logic device with a *fixed OR array and a programmable AND* array.
- Because only the AND gates are programmable, the PAL is easier to program than but is not as flexible as the PLA.
- > The PAL is a programmable logic device with a fixed OR array and a programmable AND array.
- > Below figure shows the logic configuration of a typical PAL with four inputs and four outputs.
- > Each input has a buffer-inverter gate, and each output is generated by a fixed OR gate.
- > There are four sections in the unit, each composed of an AND–OR array that is *three wide*.
- Each AND gate has 10 programmable input connections, shown in the diagram by 10 vertical lines intersecting each horizontal line.
- > The horizontal line symbolizes the multiple-input configuration of the AND gate.
- One of the outputs is connected to a buffer-inverter gate and then fed back into two inputs of the AND gates.

### Example:

### Implement the following Boolean functions, using PAL.

(May 2013)

 $w(A, B, C, D) = \sum (2, 12, 13)$   $x(A, B, C, D) = \sum (7, 8, 9, 10, 11, 12, 13, 14, 15)$   $y(A, B, C, D) = \sum (0, 2, 3, 4, 5, 6, 7, 8, 10, 11, 15)$  $z(A, B, C, D) = \sum (1, 2, 8, 12, 13)$ 

Sol:

### Simplify the functions using K Map:





|    |      | Z  |    |    |
|----|------|----|----|----|
| B  | ° cd | СD | CD | сБ |
| ĀB | 0    | 1  | 0  | 1  |
| ĀB | 0    | 0  | 0  | 0  |
| АВ | (1   | 1  | 0  | 0  |
| AB | 1    | 0  | 0  | 0  |

 $Z \grave{\Rightarrow} \underline{ABC} + \overline{ABCD}$  $+ \overline{ACD} + \overline{ABCU}$  $\Rightarrow \underline{W} + \overline{ACD} + \overline{ABCU}$ 

### PAL Programming Table:

| PAL | Programming | Table |
|-----|-------------|-------|
|-----|-------------|-------|

| Produc | t | A | ND Inp | uts |   |                |
|--------|---|---|--------|-----|---|----------------|
| Term   | A | В | с      | Ð   | W | Outputs        |
| 1      | 1 | I | 0      |     |   | w = ABC'       |
| 2      | 0 | 0 | 1      | 0   | _ | + A'B'CD'      |
| 3      | - | - | -      | _   | - |                |
| 4      | 1 |   | -      |     | _ | x = A          |
| 5      | - | 1 | 1      | 1   | - | + BCD          |
| 6      | - | - | -      | -   | - |                |
| 7      | 0 | 1 | _      | _   |   | <i>y</i> = A'B |
| 8      | _ | - | 1      | 1   | _ | + CD           |
| 9      | - | 0 | -      | 0   |   | + B'D'         |
| 10     |   |   | -      | -   | ł | z = w          |
| 11     | I | - | 0      | 0   | - | +AC'D'         |
| 12     | 0 | 0 | 0      | ì   | _ | + A'B'C'D      |

.

### PAL Logic Diagram:



\*\*\*\*\*

[NOV/DEC 2021]

### Problem 1:

Implement the following function using PLA

 $A(x, y, z) = \sum m(1, 2, 4, 6)$  $B(x, y, z) = \sum m(0, 1, 6, 7)$  $\mathcal{C}(x,\,y,\,z)=\sum m(2,\,6).$ yz yz Ans: х X (1) $\mathbf{B} = \overline{xy} + xy$  $A = \overline{xyz} + x\overline{z} + y\overline{z}$ yz x 

 $C = y\overline{z}$ 

PLA Programming Table:

| Product                     |                             | Inputs |   | Outputs    |      |       |  |  |
|-----------------------------|-----------------------------|--------|---|------------|------|-------|--|--|
| Term                        | x                           | у      | z | A          | В    | С     |  |  |
| $\overline{x}\overline{y}z$ | 0                           | 0      | 1 | 1          | ŧ    | .Ø    |  |  |
| x Z                         | <sup>1</sup> T <sup>2</sup> | 1012   | 0 | 1          | 14   |       |  |  |
| $y\bar{z}$                  | -                           | 1      | 0 | 3 1        | - Tr | 51(5) |  |  |
| $\overline{x} \overline{y}$ | 0                           | 0      | - | 10.<br>/_m | 1    | E     |  |  |
| xy                          | 1                           | 1      | - | -          | 1    | -     |  |  |

## PLA Logic Diagram:



\*\*\*\*\*

### PLA Problems:

(May 2017)

Implement the switching function:

$$Z_{1} = a\overline{b}\overline{d}e + \overline{a}\overline{b}\overline{c}\overline{d}e + bc + de$$

$$Z_{2} = \overline{a}\overline{c}e$$

$$Z_{3} = bc + de + \overline{c}\overline{d}\overline{e} + bd$$

$$Z_{4} = \overline{a}\overline{c}e + ce \quad \text{using 5} \times 8 \times 4 \text{ PLA}$$

Solution :

| S.No. | Product Term | Inputs    | Outputs           |  |  |
|-------|--------------|-----------|-------------------|--|--|
|       |              | abcde     | $Z_1 Z_2 Z_3 Z_4$ |  |  |
| 1     | abde         | 10-01     | 1                 |  |  |
| 2     | abcde        | 0 0 0 0 0 | 1                 |  |  |
| 3     | bc           | - 1 1     | 1 - 1 -           |  |  |
| 4     | de           | 1 1       | 1 - 1 -           |  |  |
| 5     | ace          | 0 - 0 - 1 | - 1 - 1           |  |  |
| 6     | cde          | 0 0 0     | 1 -               |  |  |
| 7     | bd           | - 1 - 1 - | 1 -               |  |  |
| 8     | се           | 1 - 1     | 1                 |  |  |

Table



Page 22

### Field-Programmable Gate Array (FPGA)

Write short notes on FPGA.(May2010,May2012, May 2013, May 2015, Nov-2016, Dec 2013, Dec 2017)) (Dec 2019

- A Field Programmable Gate Array (FPGA) is a VLSI circuit that can be programmed at the user's location.
- A typical FPGA consists of an array of millions of logic blocks, surrounded by programmable input and output blocks and connected together via programmable interconnections.
- > There is a wide variety of internal configurations within this group of devices.
- The performance of each type of device depends on the circuit contained in its logic blocks and the efficiency of its programmed interconnections.



Fig: Large programmable-logic-device scaling approaches: (a) CPLD; (b) FPGA.

- > A typical FPGA logic block consists of lookup tables, multiplexers, gates, and flip- flops.
- A lookup table is a truth table stored in an SRAM and provides the combinational circuit functions for the logic block.
- The combinational logic section, along with a number of programmable multiplexers, is used to configure the input equations for the flipflop and the output of the logic block.
- An FPGA contains a number of relatively independent configurable logic modules, configurable I/Os and programmable interconnection paths or routing channels.
- All the resources of this device are uncommitted and these must be selected, configured, and interconnected by the user to form a logic system for his application.
- FPGAs are specified by their size, configuration of their logic modules, and interconnection requirements.
- FPGA with larger logic modules may not be sufficiently utilized to perform simple logic functions and thereby wasting the logic modules.

- Use of smaller logic modules leads to a larger number of interconnections with the device causing significant propagation delay as well as consuming a large percentage of FPGA area.
- The designer must optimize the logic module size and interconnection requirements according to the application of logic system design.
- For a given FPGA device, there are many possible ways to configure to meet the design requirements.
- The *advantage* of using RAM instead of ROM to store the truth table is that the table can be programmed by writing into memory.
- The *disadvantage* is that the memory is volatile and presents the need for the lookup table's content to be reloaded in the event that power is disrupted.
- > The program can be downloaded either from a host computer or from an onboard PROM.
- The program remains in SRAM until the FPGA is reprogrammed or the power is turned off. The device must be reprogrammed every time power is turned on.

### **Basic Xilinx Architecture:**

The basic architecture of Spartan and earlier device families consists of an array of configurable logic blocks (CLBs), a variety of local and global routing resources, and input-output (I/O) blocks (IOBs), programmable I/O buffers, and an SRAM based configuration memory, as shown in Fig.



### CHARACTERISTICS OF DIGITAL IC

### Explain the various parameters used in logic families.

- The various digital logic families are usually evaluated by comparing the characteristics of the basic gates of each family.
- > The most important governing parameters of various logic families are listed below.
  - 1. Propagation delay (speed of operation).
  - 2. Power dissipation.
  - 3. Fan in.
  - 4. Fan out.
  - 5. Noise immunity.
  - 6. Operating temperature.
  - 7. Power supply requirement.
  - 8. Current and voltage parameters.

### **Propagation Delay:**

- Propagation delay is defined as the time taken for the output of a logic gate to change after the inputs have changed.
- > It is the transition time for the signal to propagate from input to output.
- > This factor governs the speed of operation of a logic circuit.



- > Two types of propagation delay times, which are defined as
  - (a) tpLH : It is the propagation delay time for a signal to change from logic LOW (0 state) to HIGH (1 state).
  - (b) tpHL: It is the propagation delay time for a signal to change from logic HIGH (1 state) to LOW (0 state).
- ➤ The delay times are measured by time lapsed between the 50% voltage levels of the
- ➢ input and the output waveforms while making the transition.

### Power dissipation:

- Power dissipation is the measure of the power consumed by logic gates when fully driven by all inputs.
- The average power or the DC power dissipation is the product of DC supply voltage and the mean current consumed from that supply.

### Fan In:

The maximum number of inputs that can be connected to a logic gate without any impairment of its normal operation is referred to as fan in.

### Fan Out:

Fan out refers to the maximum number of standard loads that the output of the gate can drive without any impairment or degradation of its normal operation.

### Noise Margin:

- Noise immunity or the noise margin is the limit of noise voltage that may appear at the input of the logic gate without any impairment of its proper logic operation.
- The difference between the operating input logic voltage level and the threshold voltage is the noise margin of the circuit.
- ▶ Noise margin is related with the input-output transfer characteristics of a logic gate.
- It depends on loading factors, power supply, operating temperature, fabrication process by the manufacturers, etc.



- From the *maximum characteristics*, any input voltage level *less than* V<sub>IL</sub> (max) is referred as low-voltage level or logic 0.
  - On the other hand, any input voltage level greater than  $V_{IH}$  (min) is referred as as high level or logic 1.

- From the *minimum characteristics*, the manufacture specifies that low level or logic 0 output voltage does not exceed V<sub>OL</sub> (max) and the high level or logic 1 output is always greater than V<sub>OH</sub> (min).
- The worst-case low-level noise margin is V<sub>IL</sub> (max) V<sub>OL</sub> (max) and the worst-case high-level noise margin is V<sub>OH</sub> (min) V<sub>IH</sub> (min).

### Explain the working principle of (i) TTL NAND gate (ii) ECL OR/NOR gate with circuit diagram. [NOV 2020] Transistor Transistor Logic (TTL)

### Explain about TTL Logic with neat diagram.

(Dec 2019 (Dec 2018

- It is a logic family implemented with bipolar process technology that combines or integrates NPN transistors, PN junction diodes and diffused resistors in a single monolithic structure to get the desired logic function.
- > The NAND gate is the basic building block of this logic family.
- Different subfamilies in this logic family such as standard TTL, low-power TTL, high-power TTL, low-power Schottky TTL, Schottky TTL, advanced low-power Schottky TTL, advanced Schottky TTL and fast TTL.

Standard TTL NAND gate:



Figure Standard TTL NAND gate.

- The circuit operates as follows; Transistor Q1 is a two-emitter NPN transistor, which is equivalent to two NPN transistors with their base and emitter terminals tied together.
- > The two emitters are the two inputs of the NAND gate.
- > Diodes  $D_2$  and  $D_3$  are used to limit negative input voltages.

- > When both the inputs are in the logic HIGH state, the current flows through the base-collector PN junction diode of transistor  $Q_1$  into the base of transistor  $Q_2$ .
- > Transistor  $Q_2$  is turned ON to saturation, with the result that transistor  $Q_3$  is switched OFF and transistor  $Q_4$  is switched ON. This produces a logic LOW at the output.

### **Totem-Pole Output Stage:**

- It is the same circuit as the open-collector gate, except for the output transistor Q4, a diode D1, and resistor 130Ω at the collector of Q4.
- > It is called the totem pole output configuration, because the transistor Q4 sits upon Q3.
- $\blacktriangleright$  The base of the transistor Q4 is driven from the collector of Q2.
- > Advantages:
  - It offers low-output impedance in both the HIGH and LOW output states.
  - Because capacitance at the output can be charged or discharged very rapidly, thus allowing quick transitions at the output from one state to the other.
  - When the output is in the logic LOW state, transistor Q4 would need to conduct a fairly large current if its collector were tied to VCC through R3 only.
  - A non-conducting Q3 overcomes this problem.

### Disadvantage

- Switch-off action of Q4 being slower than the switch-on action of Q3.
- Therefore, a small fraction of time, both the transistors are conducting, thus drawing heavy current from the supply.

#### **NOT Gate (or Inverter):**

It is just the same as that of the NAND gate except that the input transistor is a normal single emitter NPN transistor instead of a multi-emitter one.



Figure Inverter in the standard TTL.

### TTL NOR Gate:

- On the input side there are two separate transistors instead of the multi-emitter transistor of the NAND gate.
- The inputs are fed to the emitters of the two transistors, the collectors of which again feed the bases of the two transistors with their collector and emitter terminals tied together.
- > The resistance values used is the same as those used in the case of the NAND gate.
- > The output stage is also the same totem-pole output stage.



Figure NOR gate in the standard TTL.

### [NOV/DEC 2021]

(May 2019)

### Tristate Gate: Explain about tristate TTL output configuration.

- A tristate gate has three output states, namely the logic LOW state, the logic HIGH state and the high-impedance state.
- An external enable input decides whether the logic gate works according to its truth table or is in the high-impedance state.
- > Figure shows the typical internal schematic of a tristate inverter with an active HIGH enable input.
- > The circuit functions as follows.
  - ✓ When the enable input is HIGH, it reverse-biases diode D1 and also applies a logic HIGH on one of the emitters of the input transistor Q1.
  - $\checkmark$  The circuit behaves like an inverter. When the enable input is LOW, diode D1 becomes

forward biased.

- ✓ A LOW enable input forces Q2 and Q4 to cut-off. Also, a forward-biased D1 forces Q3 to cut-off.
- ✓ With both output transistors in cut-off, the output essentially is an open circuit and thus presents high output impedance.



Fig: Tristate inverter in the TTL

\*\*\*\*\*\*



### Explain about RTL logic family.

- Each input is associated with one resistor and a transistor. The collectors of the transistors are tied together with a common resistor to the V<sub>CC</sub> supply.
- > The output is taken from the collectors joint.
- > The voltage levels of the circuit are 0.2 V for low level and 1 to 3.6 V for high level.
- > If any of the inputs is at high level, the corresponding transistor is at saturation.
- This causes the output at low irrespective of the conditions of other transistors, as all the transistors are connected in parallel.
- ▶ If all the inputs are at low level at 0.2 V, all the transistors are at cut-off condition.
- > Because base-to-emitter voltage of all the transistors  $V_{BE} < 0.6$  V, causing the output of the circuit at high level approaching the value of the supply voltage  $V_{CC}$ .
- > Thus confirms the conditions of a NOR logic.
- Note that the noise margin for low signal input is 0.6 0.2 = 0.4 V.



### **Drawbacks:**

- Reduce the switching speed of the circuit.
- ➤ It degrades the rise and fall times of any input pulse.
- Reduction in base resistors reduces the input resistance, increases power consumption, and decreases the fan in.

The following are the characteristics of the RTL family.

- 1. Speed of operation is low, i.e., the propagation delay is high up to the order of 500 ns. It cannot operate at more than 4 MHz.
- 2. Fan out is 4 or 5 with a switching delay of 50 ns and fan in is 4.
- 3. Poor noise immunity.
- 4. High average power dissipation. Elimination of base resistors in RTL will reduce the power dissipation, which results in Direct-coupled Transistor Logic (DCTL).
- 5. Sensitive to temperature.

\*\*\*\*\*\*\*\*\*



Programmed PLA;



### Problem:

Design combinational circuits to convert binary coded decimal number into an excess-3 code using PLA. (May 2018)

| BCD Code       |                |                |                | Excess-3 Code  |                |                |                |
|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| B <sub>3</sub> | B <sub>2</sub> | B <sub>1</sub> | B <sub>0</sub> | E <sub>3</sub> | E <sub>2</sub> | E <sub>1</sub> | E <sub>0</sub> |
| 0              | 0              | 0              | 0              | 0              | 0              | 1              | 1              |
| 0              | 0              | 0              | 1              | 0              | 1              | 0              | 0              |
| 0              | 0              | 1              | 0,             | 0              | 1              | 0              | 1              |
| 0              | 0              | 1              | 1              | 0              | 1              | 1              | 0              |
| 0              | 1              | 0              | 0              | 0              | 1              | 1              | 1              |
| 0              | 1              | 0              | 1              | 1              | - 0            | 0              | q              |
| 0              | 1              | 1              | 0              | 1              | 0              | 0              | 1              |
| 0              | 1              | 1              | 1              | 1              | 0              | 1              | 0              |
| 1              | 0              | 0              | 0              | 1              | 0              | 1              | 1              |
| 1              | 0              | 0              | 1              | 1              | 1              | 0              | 0              |

Step 1: Truth Table

Step 2: K-Map for Excess-3





### PLA Logic Diagram:



### **TWO MARKS**

### 1. Define a memory cell. Give an example.

Memories are made up of registers. Each register consists of storage elements, each of which stores one bit of data. Such a storage element is called memory cell. Example: RAM, ROM

### 2. Define a memory location.

Memories are made up of registers. Each register in the memory is one storage location also called memory location. Each memory location is identified by an address.

### 3. List basic types of programmable logic devices.

- Programmable Read only memory
- Programmable logic Array
- Programmable Array Logic

### 4. What is volatile memory? Give an example.

The memory which cannot hold data when power is turned off is known as volatile memory. Example: static RAM

### 5. What is non-volatile memory?

The memory which can hold data even when power is turned off is known as volatile memory. Example: ROM

### 6. What is ROM?

- > A read only memory (ROM) is a device that includes both the decoder and the OR gates within a single IC package.
- $\blacktriangleright$  The number of distinct addresses possible with n input variables is  $2^n$ .

### 7. Define address and word.

In a ROM, each bit combination of the input variable is called on address.

Each bit combination that comes out of the output lines is called a word.

### 8. Name the types of ROM.

There are four types of ROM.

- Masked ROM (Masked Read only memory)
- PROM (Programmable ROM)
- EPROM (Erasable Programmable ROM)
- EEPROM or E2 PROM (Electrically Erasable PROM)

### (Dec 2013)

(Dec 2007, Dec-2013)

### (May 2011, Dec 2011)

## (May-2006)

(May-2007, Dec-2004, Dec-2006, Dec2011)

### 9. What is meant by static and dynamic memories?

Volatile memories which can hold data as long as power is ON are called static RAM (SRAM).

Dynamic RAM (DRAM) stores data as a charge on the capacitor and they need refreshing of charge on a capacitor after every millisecond to hold data even if power is ON.

### 10. What is programmable logic array? How it differs from ROM?

A PLA is similar to a ROM in concept, however it does not provide full decoding of the variables and does not generates all the minterms as in the ROM.

### **11. What is PROM?**

PROM (Programmable Read Only Memory).

It allows user to store data or program. PROMs use the fuses with material like nichrome and polycrystalline. The user can blow these fuses by passing around 20 to 50 mA of current for the period 5 to 20µs. The blowing of fuses is called programming of ROM. The PROMs are one time programmable. Once programmed, the information is stored permanent.

### 12. What is EPROM?

EPROM (Erasable Programmable Read Only Memory)

- ✓ This can be restructured to the initial state even though it has been programmed previously.
- ✓ It is *erased* by placing under a special *ultraviolet light* for a given length of time.

### 13. What is EEPROM?

EEPROM (Electrically Erasable Programmable Read Only Memory)

- Electrical signals are used to erase the previously programmed connections instead of ultraviolet light.
- > The advantage is that the device can be erased without removing it from its socket.

### 14. How individual location in an EEPROM programmed or erased? (May 2006)

It is electrically erasable memory, by activating particular row and column it is possible that individual can be programmed or erased.

### 15. What are the advantages of EPROM over PROM?

PROM is one time programmable but EPROM can be programmed multiple times. The data stored in it can be erased by exposing ultraviolet light by 15 to 20 minutes. Once erased, it can be reprogrammed.

### (Nov-2016)

(Nov-2016)

(May 2006, May 2007, Dec 2006)

#### 16. Compare and contrast EEPROM and Flash memory.

**EEPROM** 

| '.         | What | is RAM?                                                                    | (Dec 2006)                          |  |  |  |  |
|------------|------|----------------------------------------------------------------------------|-------------------------------------|--|--|--|--|
| is slower. |      |                                                                            | memory is faster.                   |  |  |  |  |
|            | 5    | Erasing and re-programming of EEPROM                                       | Erasing and re-programming of Flash |  |  |  |  |
| Ī          | 4    | Erasing is done individual byte wise.Erasing is done in one bulk operation |                                     |  |  |  |  |
|            | 3    | Consumes higher power.                                                     | Consumes less power.                |  |  |  |  |
| ľ          | 2    | Higher cost per bit.                                                       | Lower cost per bit.                 |  |  |  |  |
| ľ          | 1    | Lower packaging density.                                                   | Higher packaging density.           |  |  |  |  |
|            |      |                                                                            |                                     |  |  |  |  |

#### 17. What is RAM?

S.No

It stands for Random Access Memory (RAM). Read and write operations can be carried out. It is volatile memory. It can hold data as power is ON.

#### 18. Give the advantages of RAM.

Advantages of RAM are:

- 1. RAM is memory where we can read as well as write the data.
- 2. This memory can be accessed randomly.
- 3. Higher speed.

#### 19. What is static memory?

Memories that consist of circuits of retaining their state as long as power is applied are known as static memories.

#### 20. Define dynamic RAM.

Dynamic RAMs use capacitors as storage elements and cannot retain data very long without capacitors being recharged by a process called refreshing.

#### 21. What is the technique adopted by DRAMs?

DRAMs use a technique called address multiplexing to reduce the number of address lines.

#### 22. Compare and contrast static and Dynamic RAM.

#### (May 2012, Dec 2009)

| S.No | Static RAM                                | Dynamic RAM                            |  |  |
|------|-------------------------------------------|----------------------------------------|--|--|
| 1    | Static RAM contains Less memory cells per | Dynamic RAM contains more memory cells |  |  |
|      | unit area.                                | per unit area.                         |  |  |
| 2    | Faster memory.                            | Slower memory compared with static     |  |  |
|      |                                           | memory.                                |  |  |
| 3    | Stores data in flip flops as single bit.  | Stores data as charge in a capacitor.  |  |  |
| 4    | Refreshing not required.                  | Periodical refreshing needed.          |  |  |
| 5    | Cost is more.                             | Cost is less.                          |  |  |

(Dec-2013)

#### (Dec 2006,,J/May 2007, Dec2011, May 2010)

#### (May 2010)

(Dec 2014)

**Flash memory** 

#### 23. Draw the basic dynamic memory cell.



#### 24. Draw the logic diagram of Memory cell.



#### 25. Draw the block diagram of dynamic Memory cell or RAM cell.

# n data input lines

#### 26. What is mask - programmable?

The user must submit a PLA program table to the manufacturer.

#### 27. List the major differences between PLA and PAL

#### PLA:

Both AND and OR arrays are programmable and Complex Costlier than PAL

#### PAL

AND arrays are programmable OR arrays are fixed Cheaper and Simpler

#### 28. Define PLD.

Programmable Logic Devices consist of a large array of AND gates and OR gates that can be programmed to achieve specific logic functions.

#### 29. Give the classification of PLDs.

PLDs are classified as PROM(Programmable Read Only Memory), Programmable Logic Array(PLA), Programmable Array Logic (PAL), and Generic Array Logic(GAL).

#### manufacturar

## (Dec 2011,Dec 2008)

#### (Dec 2015)

(Dec 2007)

#### (May 2014)

(Dec 2017)(May 2013)

#### 30. Compare PLDs.

| Туре | AND array connections    | OR array connections     |
|------|--------------------------|--------------------------|
| PROM | Fixed at factory         | Programmable by Customer |
| PLA  | Programmable by Customer | Programmable by Customer |
| PAL  | Programmable by Customer | Fixed at factory         |

#### **31. Define PROM.**

PROM is Programmable Read Only Memory. It consists of a set of fixed AND gates connected to a decoder and a programmable OR array.

#### **32. Define PLA.**

PLA is Programmable Logic Array (PLA). The PLA is a PLD that consists of a programmable AND array and a programmable OR array.

#### 33. Define PAL.

PAL is Programmable Array Logic. PAL consists of a programmable AND array and a fixed OR array with output logic.

#### 34. Why was PAL developed?

It is a PLD that was developed to overcome certain disadvantages of PLA, such as longer delays due to additional fusible links that result from using two programmable arrays and more circuit complexity.

#### 35. Why the input variables to a PAL are buffered?

The input variables to a PAL are buffered to prevent loading by the large number of AND gate inputs to which available or its complement can be connected.

#### 36. Compare PLA and PAL. (Dec -10)(May 2011,May 2013,May 2017,Dec 2011)

| S.No. | PLA                                      | PAL                                   |
|-------|------------------------------------------|---------------------------------------|
| 1     | Both AND and OR arrays are               | OR array is fixed and AND array is    |
|       | programmable                             | programmable                          |
| 2     | Costliest and complex than PAL           | Cheaper and simpler                   |
| 3     | AND array can be programmed to get       | AND array can be programmed to get    |
|       | desired minterms                         | desired minterms                      |
| 4     | Any Boolean functions in SOP form can be | Any Boolean functions in SOP form can |
|       | implemented using PLA                    | be implemented using PLA              |

#### **37.** List the configurable elements in the FPGA architecture.

The FPGA architecture consists of three types of configurable elements.

- Input / Output Blocks(IOBs)
- Configurable Logic Blocks(CLBs)

#### (Dec 2019

#### (Dec 2019 (May 2008)

#### (Dec 2009)

(Dec 2009)

#### **38. Differentiate ROM and PLD**

| S.No | ROM (Read only Memory)                        | PLD (Programmable Logic Array)            |
|------|-----------------------------------------------|-------------------------------------------|
| 1.   | It is a device that includes both the decoder | It is a device that includes both AND and |
|      | and the OR gates with in a single IC package. | OR gates within a single IC package.      |
| 2.   | ROM does not full decoding of the variables   | PLD does not provide full decoding of the |
|      | and does generate all the minterms.           | variable and does not generate all the    |
|      |                                               | minterms.                                 |

Interpret about programmable logic array and infer how it differs from ROM. [NOV 2020]39. Compare the features of PROM,PAL and PLA.\$\vee\$2018\$)(May 2009,May 2012)

| S.No. | PROM                      | PLA                        | PAL                       |
|-------|---------------------------|----------------------------|---------------------------|
| 1     | AND array is fixed and    | Both AND and OR arrays     | OR array is fixed and AND |
|       | OR array is programmable  | are programmable           | array is programmable     |
| 2     | Cheaper and simple to use | Costliest and complex than | Cheaper and simpler       |
|       |                           | PAL                        |                           |
| 3     | All minterms are decoded  | AND array can be           | AND array can be          |
|       |                           | programmed to get desired  | programmed to get desired |
|       |                           | minterms                   | minterms                  |
| 4     | Only Boolean functions in | Any Boolean functions in   | Any Boolean functions in  |
|       | standard SOP form can be  | SOP form can be            | SOP form can be           |
|       | implemented using PROM    | implemented using PLA      | implemented using PLA     |

#### 40. Give the comparison between PROM and PLA.

| S.No | PROM                               | PLA                        |
|------|------------------------------------|----------------------------|
| 1    | AND array is fixed and OR array is | Both AND and OR arrays are |
|      | programmable.                      | Programmable.              |
| 2    | Cheaper and simple to use.         | Costliest and complex than |
|      |                                    | PROM.                      |

#### 41. What is FPGA?

#### (Dec 2016)

FPGA stands for Field Programmable Gate Array, which is the next generation in the programmable PLDs. The word 'field' refers to the ability of the gate arrays to be programmed for a specific function by the end user. The word 'array' indicates a *series of columns and rows of gates that can be programmed* by the end user.

#### 42. What is volatile and Non-Volatile memory?

In volatile memory the contents present in the memory *will be lost* when the power is removed.

In Non-volatile memory the contents present in the memory is not lost when the power is removed.

#### 43. What is access time and cycle time?

The access time of memory is the time required to select a word and read it.

The cycle time of memory is the time required to complete a write operation.

44. Draw the logic diagram of static and Bipolar RAM cell.



45. What are the advantages of static RAM and Dynamic Ram? [April/May-2010,Nov/Dec-2009]

#### Static RAM:

- $\checkmark$  Access time is less.
- ✓ Fast operation.

#### Dynamic Ram

- $\checkmark$  It consumes less power.
- ✓ Cost is low.

#### 46. Mention few applications of PLA and PAL.

- ✓ Implement combinational circuits
- ✓ Implement sequential circuits
- $\checkmark$  Code converters
- ✓ Microprocessor based systems

#### 47. List the advantages of PLDs.

- $\checkmark$  Low and fixed (two gate) propagation delays (typically down to 5 ns),
- ✓ Simple,
- ✓ Low-cost (free),
- ✓ Design tools.

#### [April/May-2012]

[April/May-2014, Nov/Dec-2010]

ration.

(Dec 2012)

(May 2014)

(Dec 2010)

(Dec 2013)

#### 48. Implement a 2-bit multiplier using ROM.

## 49. What is the memory capacity of RAM if it has 10bit address lines? (Dec 2017)

Memory capacity =  $2^n = 2^{10}$ 

N= address lines

Hence, 1024 bytes is the memory capacity of 10 bit address lines.

#### 50. How does ROM retain information?

A ROM chip is a non-volatile storage medium, which means it does not require a constant source of power to retain the information stored on it.

 51. Define the term Fan out.
 [NOV/DEC 2021]
 [Nov/Dec-2011]
 [Dec 2019]

It is the maximum number of inputs which have same family that the gate can drive maintaining its output within the specified limits.

#### 52. What is the significance of high impedance state in tri-state gates? [Nov/Dec-2010]

- > High impedance state of a three-state gate provides a special feature not available in other gates.
- Because of this features a larger number of three state gate output can be connected with wires to form a common line without endangering loading effects.

#### 53. Write a note on tri-state gates.

It is a digital circuit that exhibits three states. Two of the states are signals equivalent to logic1 and logic 0. The third state is high impedance state. High impedance state behaves like a open circuit.

#### 54. State the advantages of CMOS logic.

- Consumes less power.
- > Operated at high voltages, resulting in improved noise immunity.
- ➢ Fan-out is more.
- Better noise margin.

#### 



(Dec 2019 [April/May-2015]

#### [Aprii/May-2015]

### (May 2017)

[Nov/Dec-2010]

#### 55. Draw the TTL Inverter (NOT) Circuit.

#### Practical inverter (NOT) circuit

#### 56. What is a totem pole output?

Totem pole output is a standard output of a TTL gate. It is specifically designed to reduce the propagation delay in the circuit and to provide sufficient output power for high fan-out.

## 57. Draw an active-high tri-state buffer and write its truth table. [April/May-2010]

Input

Enable

0

 $\frac{1}{1}$ 

#### 58. What is TTL logic?

It is a logic family implemented with bipolar process technology that combines or integrates NPN transistors, PN junction diodes and diffused resistors in a single monolithic structure to get the desired logic function.

Input

Х

0

1

Output

Output

Ζ

0

1

#### 59. Interpret Read and Write Operation.

The process of storing new information into memory is referred to as a memory "write" operation.

The process of transferring the stored information out of memory is referred to as a memory "read" operation.



#### [April/May-2012]

[April/May-2011]

#### (Dec 2018)

 $\begin{array}{ll} \mbox{60. A Standard TTL gate has the following current specifications: } I_{OH} = 400 \mu A, \ I_{IH} = 40 \mu A, \\ I_{OH} = 16 m A, \ I_{IL} = 1.6 m A. \ Calculate the fanout. \end{array} \eqno(May 2019)$ 

Sol:  
(Fanout)<sub>h</sub> = 
$$\frac{IOH}{IIH} = \frac{400\mu A}{40\mu A} = 10\mu A$$
  
(Fanout)i =  $\frac{IOL}{IIL} = \frac{16mA}{1.6mA} = 10mA$ 

61. A DRAM chip uses two dimensional address multiplexing. It has 13 common address pins with the row address having one bit more than the column address. What is the capacity of the memory? [NOV/DEC 2021] (May 2019)

Sol:

n= 13 address pins Memory capacity= 2<sup>n</sup> = 2<sup>13</sup> = 8192 bytes

#### 62. What do you mean by propagation delay and noise margin ? [NOV 2020]

Noise immunity or the noise margin is the limit of noise voltage that may appear at the input of the logic gate without any impairment of its proper logic operation.

Propagation delay is defined as the time taken for the output of a logic gate to change after the inputs have changed.

#### 63. Define the term 'fan-in'. [NOV/DEC 2021]

The maximum number of inputs that can be connected to a logic gate without any impairment of its normal operation is referred to as fan in.

Explain the working principle of ECL OR/NOR gate with circuit diagram. [NOV 2020] ECL OR/NOR gate:



This is a NOR/OR gate using emitter-coupled logic, a high-speed type of logic using transistors. The two inputs are shown at left. If either one of them is high (-700 mV), then the OR output is high, and the NOR output is low. If they are both low (-1.4V), then the OR is low, and NOR is high.

Q3's base voltage is fixed at a level where there is enough base current to get Q3 to conduct. This brings Q3's collector down to about 740 mV, which brings the OR output low (through a follower attached to Q3's collector). Q3's emitter is high enough relative to Q2's base that Q2 can't conduct, so Q2's collector stays at ground. This keeps the NOR output high (through a follower).

If either of the two inputs is high, then the corresponding transistor conducts. This brings Q1/Q2's collector low, which brings the NOR output low. It also brings Q1/Q2's emitter high enough so that Q3 can't conduct, which brings the OR output high.

The advantage of ECL is speed, because the transistors are never in saturation. They are either in cutoff or forward-active mode; transistors can switch between these two states quickly. The disadvantage is that there is always a lot of current, and therefore power consumption.

# Analyze the working principle and characteristics of CMOS (i) inverter (ii) NAND gate (iii) NOR gate with circuit diagram. [NOV 2020]

#### **CMOS Working Principle and Applications**

- The term CMOS stands for "Complementary Metal Oxide Semiconductor".
- CMOS technology is one of the most popular technology in the computer chip design industry and broadly used today to form integrated circuits in numerous and varied applications.
- Today's computer memories, CPUs and cell phones make use of this technology due to several key advantages.
- This technology makes use of both P channel and N channel semiconductor devices. One of the most popular MOSFET technologies available today is the Complementary MOS or CMOS technology.
- This is the dominant semiconductor technology for microprocessors, microcontroller chips, memories like RAM, ROM, EEPROM and application specific integrated circuits (ASICs).

#### CMOS (Complementary Metal Oxide Semiconductor)

• The main advantage of CMOS over NMOS and BIPOLAR technology is the much smaller power dissipation.

- Unlike NMOS or BIPOLAR circuits, a Complementary MOS circuit has almost no static power dissipation.
- Power is only dissipated in case the circuit actually switches.
- This allows integrating more CMOS gates on an IC than in NMOS or bipolar technology, resulting in much better performance.
- Complementary Metal Oxide Semiconductor transistor consists of P-channel MOS (PMOS) and N-channel MOS (NMOS).



#### NMOS

- NMOS is built on a p-type substrate with n-type source and drain diffused on it.
- In NMOS, the majority carriers are electrons.
- When a high voltage is applied to the gate, the NMOS will conduct.
- Similarly, when a low voltage is applied to the gate, NMOS will not conduct.
- NMOS are considered to be faster than PMOS, since the carriers in NMOS, which are electrons, travel twice as fast as the holes.



#### PMOS

- P- channel MOSFET consists P-type Source and Drain diffused on an N-type substrate.
- Majority carriers are holes. When a high voltage is applied to the gate, the PMOS will not conduct.
- When a low voltage is applied to the gate, the PMOS will conduct.
- The PMOS devices are more immune to noise than NMOS devices.



#### **CMOS Working Principle**

- In CMOS technology, both N-type and P-type transistors are used to design logic functions.
- The same signal which turns ON a transistor of one type is used to turn OFF a transistor of the other type.
- This characteristic allows the design of logic devices using only simple switches, without the need for a pull-up resistor.
- In CMOS logic gates a collection of n-type MOSFETs is arranged in a pull-down network between the output and the low voltage power supply rail (Vss or quite often ground). Instead of

the load resistor of NMOS logic gates, CMOS logic gates have a collection of p-type MOSFETs in a pull-up network between the output and the higher-voltage rail (often named Vdd).

- Thus, if both a p-type and n-type transistor have their gates connected to the same input, the p-type MOSFET will be ON when the n-type MOSFET is OFF, and vice-versa.
- The networks are arranged such that one is ON and the other OFF for any input pattern as shown in the figure below.



#### CMOS Logic Gate using Pull-Up and Pull-Down Networks

- CMOS offers relatively high speed, low power dissipation, high noise margins in both states, and will operate over a wide range of source and input voltages (provided the source voltage is fixed).
- Furthermore, for the better understanding of the Complementary Metal Oxide Semiconductor working principle, we need to discuss in brief about CMOS logic gates as explained below.

#### **CMOS Inverter**

• The inverter circuit as shown in the figure below. It consists of PMOS and NMOS FET. The input A serves as the gate voltage for both transistors.



#### **CMOS Inverter**

- The NMOS transistor has an input from Vss (ground) and PMOS transistor has an input from Vdd. The terminal Y is output. When a high voltage (~ Vdd) is given at input terminal (A) of the inverter, the PMOS becomes open circuit and NMOS switched OFF so the output will be pulled down to Vss.
- When a low-level voltage (<Vdd, ~0v) applied to the inverter, the NMOS switched OFF and PMOS switched ON. So the output becomes Vdd or the circuit is pulled up to Vdd.

| INPUT | LOGIC INPUT | OUTPUT | LOGIC OUTPUT |
|-------|-------------|--------|--------------|
| 0 v   | 0           | Vdd    | 1            |
| Vdd   | 1           | 0 v    | 0            |

#### CMOS NAND Gate

The below figure shows a 2-input Complementary MOS NAND gate. It consists of two series NMOS transistors between Y and Ground and two parallel PMOS transistors between Y and VDD.



CMOS NAND Gate

If either input A or B is logic 0, at least one of the NMOS transistors will be OFF, breaking the path from Y to Ground. But at least one of the pMOS transistors will be ON, creating a path from Y to VDD. Hence, the output Y will be high. If both inputs are high, both of the nMOS transistors will be ON and both of the pMOS transistors will be OFF. Hence, the output will be logic low. The truth table of NAND logic gate is given in below table.

| Α | В | Pull-Down | Pull-up<br>Network | OUTPUT Y |
|---|---|-----------|--------------------|----------|
|   |   | Network   | Network            |          |
| 0 | 0 | OFF       | ON                 | 1        |
| 0 | 1 | OFF       | ON                 | 1        |
| 1 | 0 | OFF       | ON                 | 1        |
| 1 | 1 | ON        | OFF                | 0        |

#### **CMOS NOR Gate**

A 2-input NOR gate is shown in the figure below. The NMOS transistors are in parallel to pull the output low when either input is high. The PMOS transistors are in series to pull the output high when both inputs are low, as given in below table. The output is never left floating.



#### **Complementary MOS NOR Gate**

The truth table of NOR logic gate given in below table

| Α | В | Y |
|---|---|---|
| 0 | 0 | 1 |
| 0 | 1 | 0 |
| 1 | 0 | 0 |
| 1 | 1 | 0 |

#### **CMOS Applications**

Complementary MOS processes were widely implemented and have fundamentally replaced NMOS and bipolar processes for nearly all digital logic applications. The CMOS technology has been used for the following digital IC designs.

- Computer memories, CPUs
- Microprocessor designs
- Flash memory chip designing
- Used to design application-specific integrated circuits (ASICs)

Derive the PLA programming table for the four Boolean functions listed below. Minimize the numbers of product terms,

A (x, y, z) = 
$$\Sigma$$
 (1, 2, 4, 6)  
B (x, y, z) =  $\Sigma$  (0, 1, 6, 7)  
C (x, y, z) =  $\Sigma$  (2, 6)  
D (x, y, z) =  $\Sigma$  (1, 2, 3, 5, 7)



$$A = yz' + xz' + x'y'z$$
$$A' = yz + xz + x'y'z'$$



.

$$C = yz^{-1}$$
$$C' = y' + z$$

#### [NOV/DEC 2021]



$$B = xy + x'y'$$
$$B' = x'y' + x'y$$



$$D = z + x'y$$
$$D' = y'z' + xz'$$

| 1          |      | t Inputs | Output |   |
|------------|------|----------|--------|---|
|            | term | xyz      |        |   |
| yz'        | 1    | -10      | 1 - 1  | - |
| yz'<br>xz' | 2    | 1 - 0    | 1      | - |
| x'y'z      | 3    | 001      | 1      | - |
| xy'        | 4    | 10-      | - 1 -  | - |
| x'y        | 5    | 01-      | - 1 -  | 1 |
| z          | 6    | 1        |        | 1 |
|            |      |          | тст    | Т |

| S.No. | Product          | sintrab Iv | Inputs  |   | ile comb | Out    | outs | ( Install |
|-------|------------------|------------|---------|---|----------|--------|------|-----------|
|       | Term             | x          | y       | z | A        | B      | C    | D         |
| 1     | $\overline{xyz}$ | 0          | 0       | 1 | 1        | -      | -    | -         |
| 2     | xz               | 1          | Cinty 1 | 0 | 1        | at Tim | 181  | 1         |
| 3     | y z              | 0 -        | 1       | 0 | 1        | -      | 1    | -         |
| 4     | $\frac{1}{xy}$   | 0          | 0       | - | -        | 1      | -    | -         |
| 5     | xy               | 1          | 1       | - | -        | 1      | -    | -         |
| 6     | $\frac{1}{yz}$   | -          | 0       | 0 | -        | -      | -    | 1         |
|       |                  |            |         |   | Т        | Т      | Т    | С         |

PLA implementation is shown below:



CS Scanned with CamScanner